js动态生成表格

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        table {
            margin: 200px auto;
            /* 表格的边框合并,如果相邻,则共用一个边框。 */
            border-collapse: collapse;
            /* 设置行与单元格边框的间距。 */
            border-spacing: 0px;

        }

        thead {
            background: blue;

        }

        th {
            border: 1px solid #222222;
        }

        td {
            padding:0 10px;
            border: 1px solid #222222;
        }
    </style>
</head>

<body>
    <table>
        <thead>
            <th>姓名</th>
            <th>科目</th>
            <th>成绩</th>
            <th>操作</th>
        </thead>
        <tbody>

        </tbody>
    </table>

    <script>
        //1.准备学生数据
        let datas = [{
            name: '李狗',
            subject: 'Javascript',
            score: 100,
        },
        {
            name: '悬浮',
            subject: 'Javascript',
            score: 66,
        },
        {
            name: '开明',
            subject: 'Javascript',
            score: 21,
        },
        {
            name: '日照',
            subject: 'Javascript',
            score: 99,
        },]
        //2.往tbody 里面创建行,有几个人(通过数组的长度) 我们就创建几行
        let tbody = document.querySelector('tbody');
        for (let i = 0; i < datas.length; i++) {//外面的for 循环管行
            let tr = document.createElement('tr');
            tbody.appendChild(tr);
            //行里面创建单元格 td 单元格的数量取决于每个对象里面的属性个数 for 循环遍历对象
            for (let key in datas[i]) {//此for 循环管列 td
                let td = document.createElement('td');
                //把对象里面的属性值 datas[i][key] 给td
                td.innerHTML = datas[i][key];
                tr.appendChild(td);
            }
            //3.创建有删除2个字的单元格
            let td = document.createElement('td');
            td.innerHTML = '<a href="javascript:;">删除</a>'
            tr.appendChild(td)
        }
        //4.删除操作 开始 
        let as=document.querySelectorAll('a')
        for(let i=0;i<as.length;i++){
            as[i].onclick=function(){
                //点击a删除 当前 a所在的行(链接的爸爸的爸爸) node.removeChild(child)
                tbody.removeChild(this.parentNode.parentNode)
            }
        }
    </script>
</body>

</html>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值