JavaScript动态生成表格

本文介绍如何使用JavaScript根据预设的数据动态生成HTML表格,并实现行内数据的删除功能。

要求:

  1. HTML标签只写一行表头
  2. 通过JS来写动态的表格(有多少组数据,就自动创建多少行表格)
  3. 为学习和演示,采用固定的数据,不涉及调用后台数据

代码实现:

HTML内容:

<table cellspacing="0">
    <thead>
        <tr>
            <th>姓名</th>
            <th>科目</th>
            <th>成绩</th>
            <th>操作</th>
        </tr>
    </thead>
    <tbody></tbody>
</table>

CSS内容:

table {
    width: 500px;
    margin: 100px auto;
    border-collapse: collapse;
    text-align: center;
}

td,
th {
    border: 1px solid #333;
}

thead tr {
    height: 40px;
    background-color: #ccc;
}

JS内容:

// 1.先准备好学生的数据,用数组形式储存,每个数组元素是一个对象
var datas = [{
    name: '张三',
    subject: 'JavaScript',
    score: 100
}, {
    name: '李四',
    subject: 'JavaScript',
    score: 98
}, {
    name: '王五',
    subject: 'JavaScript',
    score: 99
}, {
    name: '赵六',
    subject: 'JavaScript',
    score: 88
}, {
    name: '哈哈',
    subject: 'JavaScript',
    score: 0
}];
// 2. 往tbody 里面创建行: 有几个人(通过数组的长度)我们就创建几行
var tbody = document.querySelector('tbody');
for (var i = 0; i < datas.length; i++) { // 外面的for循环管行 tr
    // 1. 创建 tr行
    var tr = document.createElement('tr');
    tbody.appendChild(tr);
    // 2. 行里面创建单元格(跟数据有关系的3个单元格) td 单元格的数量取决于每个对象里面的属性个数  for循环遍历对象 datas[i]
    for (var k in datas[i]) { // 里面的for循环管列 td
        // 创建单元格 
        var td = document.createElement('td');
        // 把对象里面的属性值 datas[i][k] 给 td  
        // console.log(datas[i][k]);
        td.innerHTML = datas[i][k];
        tr.appendChild(td);
    }
    // 3. 创建有删除2个字的单元格 
    var td = document.createElement('td');
    td.innerHTML = '<a href="javascript:;">删除</a>';
    tr.appendChild(td);

}
// 4. 删除操作
var as = document.querySelectorAll('a');
for (var i = 0; i < as.length; i++) {
    as[i].onclick = function() {
        // 点击a删除 当前a所在的行(a父节点的父节点)  node.removeChild(child)  
        tbody.removeChild(this.parentNode.parentNode)
    }
}
// for(var k in obj) {
//     k 得到的是属性名
//     obj[k] 得到是属性值
// }

实现效果:


点击删除按钮,相应的行会删除。
点击删除“张三”的数据:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

火星飞鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值