zoukankan      html  css  js  c++  java
  • 13-动态创建表格

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>Document</title>
      <style>
        #box table {
          border-collapse: collapse;
        }
      </style>
    </head>
    <body>
      <div id="box"></div>
      <script src="common.js"></script>
      <script>
        // var s = {name: 'zs', subject: '语文', score: 90};
        // 模拟数据
        var datas = [
          {name: 'zs', subject: '语文', score: 90},
          {name: 'ls', subject: '数学', score: 80},
          {name: 'ww', subject: '英语', score: 99},
          {name: 'zl', subject: '英语', score: 100},
          {name: 'xs', subject: '英语', score: 60},
          {name: 'dc', subject: '英语', score: 70}
        ];
    
        // 表头数据
        var headDatas = ['姓名', '科目', '成绩', '操作'];
    
        // 1 创建table 元素
        var table = document.createElement('table');
        my$('box').appendChild(table);
        table.border = '1px';
        table.width = '400px';
    
        // 2 创建表头
        var thead = document.createElement('thead');
        table.appendChild(thead);
    
        var tr = document.createElement('tr');
        thead.appendChild(tr);
        tr.style.height = '40px';
        tr.style.backgroundColor = 'lightgray';
    
        // 遍历头部数据,创建th
        for (var i = 0; i < headDatas.length; i++) {
          var th = document.createElement('th');
          tr.appendChild(th);
          // th.innerText
          setInnerText(th, headDatas[i]);
        }
        
        // 3 创建数据行
        var tbody = document.createElement('tbody');
        table.appendChild(tbody);
        tbody.style.textAlign = 'center';
        for (var i = 0; i < datas.length; i++) {
          // 一个学生的成绩 {name: 'zl', subject: '英语', score: 100},
          var data = datas[i];
          tr = document.createElement('tr');
          tbody.appendChild(tr);
    
          // 遍历对象
          for (var key in data) {
            var td = document.createElement('td');
            tr.appendChild(td);
            setInnerText(td, data[key]);
          }
          // 生成删除对应的列
          td = document.createElement('td');
          tr.appendChild(td);
          // 删除的超链接
          var link = document.createElement('a');
          td.appendChild(link);
          link.href = 'javascript:void(0)';
          setInnerText(link, '删除');
    
          link.onclick = linkDelete;
        }
    
        function linkDelete() {
          // removeChild()
          // 获取父元素
          // 
          // 获取要删除的行
          var tr = this.parentNode.parentNode;
          tbody.removeChild(tr);
          return false;
        }
      </script>
    </body>
    </html>
    别废话,拿你代码给我看。
  • 相关阅读:
    【js】栈方法和队列方法
    adb devices 不能连接设备 could not install *smartsocket* listener
    mysql无法启动服务,错误1067
    Sql Server存储过程详解
    ef not in
    checkbox多选框取值
    Linq 常用操作(增删改)
    二进制与图片相互转换
    jQuery 二级联动
    百度地图API功能
  • 原文地址:https://www.cnblogs.com/lvxueyang/p/13707413.html
Copyright © 2011-2022 走看看