zoukankan      html  css  js  c++  java
  • JS-纯js制作动态成绩表(流程控制语句+js内置对象)

    流程控制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>

  • 相关阅读:
    对数据库文件信息进行批量删除
    php多条件查询
    实现条件查询
    在PHP中设置封装类文件
    php中什么是一维数组什么是二维数组
    登录注册的学习
    git系列---【git提交代码时,文件名过长导致报错:libgit2 returned: invalid path for filesystem】
    git系列---【初始工程文件太大或者文件数太多时,向远程仓库push时总是失败,如何解决?】
    git系列---【git的撤销命令】
    git系列---【git新建分支时,已经推送到远程,发现分支名错了,如何修改分支名,并推送到远程?】
  • 原文地址:https://www.cnblogs.com/padding1015/p/5854951.html
Copyright © 2011-2022 走看看