流程控制for循环+if判断+Math对象+Array对象+Date对象制作成绩表

<!DOCTYPE html>
<html>

<head>
<meta charset="UTF-8">
<title>综合运用</title>
<style type="text/css">
body {
text-align: center;
font: 14px "微软雅黑";
}

td {
padding: 8px 10px;
}

table {
display: inline-block;
border: 5px solid #6495ED;
}

caption {
background-color: #6495ED;
color: white;
padding: 10px 5px;
}
</style>
</head>

<body>
<h1>流程控制for循环+if判断+Math对象+Array对象+Date对象制作成绩表</h1> //monthArr[mydate.getMonth()] + '月'; 这里注意,直接导出getMonth的值,会比实际月份少1,这是因为,月份是从1-12,而getMonth返回的值则是从0-11,就和星期的返回方法是一样的。所以解决方法也一样,利用返回的值,当做数组的下标调用,对应出正确的月份。用alert(mydate.getMonth())才发现了这个问题,进而解决掉。所以说alert是调试bug的必备良药。
<!--
求和公式
var sum = 0;
for(var i=0;i<myArr.length;i++){
sum += myArr[i][1];
// alert(myArr[i][1]);
// document.write(myArr[i][0]+'<br />');
}
// document.write(sum);
document.getElementById('sum').innerText = sum;
求平均数
var pjf = sum/myArr.length;
document.getElementById('b').innerHTML = Math.round(pjf);
其他不成熟也不成功的小实验
// document.getElementById('b').innerText = Math.round(Math.sqrt(sum));//四舍五入(算术平方根(sum和的值))//document.write(Math.pow(Math.sqrt(sum),2));-->

<h1>法2——for循环制作表格</h1>
<script type="text/javascript">
//成绩信息
var myArr = [
['小明', 87],
['小花', 81],
['小红', 97],
['小天', 76],
['小张', 54],
['小小', 94],
['小西', 90],
['小舞', 66],
['小迪', 64],
['小曼', 76]
];
//月份
var month = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12];
//星期
var day = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
var mydate = new Date(); //var year = mydate.getFullYear();

//日期
var datearr = [mydate.getFullYear() + '年', month[mydate.getMonth()] + '月', mydate.getDate() + '日', day[mydate.getDay()]];

//总分
var sum = 0; //这里一定要定义为0,这样也算声明sum是一个数值的方式,不然直接var sum。会返回NaN,不是一个数值
for(var s = 0; s < myArr.length; s++) {
sum += parseInt(myArr[s][1]);
// alert(myArr.length);
// alert(myArr[s][1]);
}
// alert(sum);
//平均分——等于总分除以班级人数
var pjf = sum / myArr.length;

// document.write(sum);
// document.write(pjf);
//最后单独添加:
myArr.push(['总分', sum], ['平均分', pjf]);

//开始写表格
document.write('<table border="1">');
document.write('<caption>181班期末成绩表</caption>');
document.write('<tr>');
for(var a = 0; a < datearr.length; a++) {
document.write('<td>' + datearr[a] + '</td>');
}
document.write('</tr>');
for(var i = 0; i < myArr.length; i++) { //实现写10行
document.write('<tr>');
for(var j = 0; j < 1; j++) { //每行写一遍
document.write('<td>' + myArr[i][0] + '</td>'); //一遍中的第一个单元格
document.write('<td>' + myArr[i][1] + '</td>'); //一遍中的第二个单元格
if(i < myArr.length-2) {//抛去最后两个不进行判断,因为最后两个是单独添加的总分和平均分。所以只有在i小于长度减去最后两个后的情况下,才能进行判断。
if(myArr[i][1] >= 80) { //判断成绩后写备注
document.write('<td>优秀</td>');
} else if(myArr[i][1] < 80 && myArr[i][1] >= 60) {
document.write('<td>及格</td>');
} else {
document.write('<td>不及格</td>');
}
}

// alert(myArr[j]);
}

document.write('</tr>');
}
document.write('</table>');
// alert(myArr.length);
// alert(myArr[i].length);
</script>
</body>

</html>

JS-纯js制作动态成绩表(流程控制语句+js内置对象)的更多相关文章

  1. JS基础-语法+流程控制语句+函数+内置对象【数组】

    JS语法: Javascript基本数据类型:undefined/null/Boolean/number/string 复杂数据类型:object typeof用来检测变量的数据类型 typeof的使 ...

  2. jsp提交表单数据乱码,内置对象,以及过滤器

    jsp提交表单数据乱码解决方案 通过form表单给服务器提交数据的时候,如果提交的是中文数据,那么可能会出现乱码,如果表单的请求方式是post请求,那么可以使用如下方案解决乱码: 在调用getPara ...

  3. JS内置对象的原型不能重定义?只能动态添加属性或方法?

    昨天马上就快下班了,坐在我对面的同事突然问我一个问题,我说“爱过”,哈哈,开个玩笑.情况是这样的,他发现JS的内置对象的原型好像不能通过字面量对象的形式进行覆盖, 只能动态的为内置对象的原型添加属性或 ...

  4. 5、前端--js常量、变量、5种基本数据类型(number string boolean undefined object)、运算符、流程控制、三元运算符、函数、自定义对象、内置对象、BOM操作

    变量与常量 在JS中声明变量需要使用关键字 老版本 var(全部都是全局变量) 新版本 let(可以声明局部变量) # 推荐使用let(其实问题不大) 在JS中声明常量也需要使用关键字 const # ...

  5. js运算符、 流程控制 、函数、内置对象、BOM与DOM操作

    运算符 # 1.算术运算符 var x=10; var res1=x++; '先赋值后自增1' var res2=++x; '先自增1后赋值' # 2.比较运算符 弱等于:自动转换类型 '5' == ...

  6. JS运算符,流程控制,函数,内置对象,BOM与DOM

    运算符 1.算数运算符 运算符 描述 + 加 - 减 * 乘 / 除 % 取余(保留整数) ++ 递加 - - 递减 ** 幂 var x=10; var res1=x++; '先赋值后自增1' 10 ...

  7. js流程控制;常用内置对象

    一.流程控制 1.if .if-else.if-else if-else var ji = 20; if(ji >= 20){ console.log('大吉大利,晚上吃鸡') } alert( ...

  8. js数组、内置对象、自定义对象

    [js中的数组] 1.数组的基本概念? 数组是在内存空间中连续存储的一组有序数据的集合 元素在数组中的顺序,称为下标.可以使用下表访问数字的每个元素. 2.如何声明一个数组? ① 使用字面量声明: 在 ...

  9. js简介 基本操作 以及循环语句 内置对象 函数044

    js 全称 javascript 从交互的角度 描述行为 一 .js注释方法: //单行注释    声明变量 var 二 .声明多个变量 :   var a = '2' ,b = 4, c = tru ...

随机推荐

  1. Retro 2013

    现在的team里每个迭代都会做一次retro,回顾这两周的情况,有哪些做得好的地方,有哪些做得不足的地方,并制定出一系列action,以期望在下一个迭代中解决这些问题.我觉得这种形式挺不错.因此今年的 ...

  2. MySQL 5.7.9版本sql_mode=only_full_group_by问题

    用到GROUP BY 语句查询时com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Expression #2 of SELECT l ...

  3. jQuery基础--样式篇(3)

    1.jQuiery对象与DOM对象 对于刚刚接触jQuery的初学者,我们要清楚认识一点:jQuery对象与DOM对象是不一样的.可能一时半会分不清楚哪些是jQuery对象,哪些是DOM对象,下面重点 ...

  4. android 之 surfaceView和普通View的重绘使用

    !自定义控件式需要实现AttrbuteSet   可在xml文件中配置略过创建该对象 普通的View只能在主线程中绘制界面,适用于简单的被动绘制 SurfaceView则可以在新线程中绘制界面,不会阻 ...

  5. [转]JAVA设计模式之单例模式

    原文地址:http://blog.csdn.net/jason0539/article/details/23297037 概念: java中单例模式是一种常见的设计模式,单例模式的写法有好几种,这里主 ...

  6. iOS开发--二维码的扫描

    一.需要包含头文件 #import <AVFoundation/AVFoundation.h> 二.通过设置<AVCaptureMetadataOutputObjectsDelega ...

  7. javascript 数组实例

    在遍历数组时, 如果想要排除 null / undefined 和 不存在的元素时,代码如下: for ( var i = 0; i < a.length; i++ ){ //跳过null / ...

  8. safe RGB colors

    RGB是面向机器的一种颜色空间. 虽然它表示\(256 \times 256 \times 256\)种不同的颜色, 但在实际中, 大部分机器都只实现了256种颜色. 安全色(Safe RGB col ...

  9. iOS9 支持http

    在Info.plist中添加NSAppTransportSecurity类型Dictionary. 在NSAppTransportSecurity下添加NSAllowsArbitraryLoads类型 ...

  10. bzoj 1208 splay模板题2

    自己yy了找前驱和后继,学了学怎么删除...(反正就是练模板) #include<iostream> #include<cstdio> #include<cstring& ...