日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

JavaScript動(dòng)態(tài)生成表格

 丹楓無(wú)跡 2021-09-14

要求:

  1. HTML標(biāo)簽只寫一行表頭
  2. 通過(guò)JS來(lái)寫動(dòng)態(tài)的表格(有多少組數(shù)據(jù),就自動(dòng)創(chuàng)建多少行表格)
  3. 為學(xué)習(xí)和演示,采用固定的數(shù)據(jù),不涉及調(diào)用后臺(tái)數(shù)據(jù)

代碼實(shí)現(xiàn):

HTML內(nèi)容:

<table cellspacing="0">
    <thead>
        <tr>
            <th>姓名</th>
            <th>科目</th>
            <th>成績(jī)</th>
            <th>操作</th>
        </tr>
    </thead>
    <tbody></tbody>
</table>

CSS內(nèi)容:

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內(nèi)容:

// 1.先準(zhǔn)備好學(xué)生的數(shù)據(jù),用數(shù)組形式儲(chǔ)存,每個(gè)數(shù)組元素是一個(gè)對(duì)象
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 里面創(chuàng)建行: 有幾個(gè)人(通過(guò)數(shù)組的長(zhǎng)度)我們就創(chuàng)建幾行
var tbody = document.querySelector('tbody');
for (var i = 0; i < datas.length; i++) { // 外面的for循環(huán)管行 tr
    // 1. 創(chuàng)建 tr行
    var tr = document.createElement('tr');
    tbody.appendChild(tr);
    // 2. 行里面創(chuàng)建單元格(跟數(shù)據(jù)有關(guān)系的3個(gè)單元格) td 單元格的數(shù)量取決于每個(gè)對(duì)象里面的屬性個(gè)數(shù)  for循環(huán)遍歷對(duì)象 datas[i]
    for (var k in datas[i]) { // 里面的for循環(huán)管列 td
        // 創(chuàng)建單元格 
        var td = document.createElement('td');
        // 把對(duì)象里面的屬性值 datas[i][k] 給 td  
        // console.log(datas[i][k]);
        td.innerHTML = datas[i][k];
        tr.appendChild(td);
    }
    // 3. 創(chuàng)建有刪除2個(gè)字的單元格 
    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() {
        // 點(diǎn)擊a刪除 當(dāng)前a所在的行(a父節(jié)點(diǎn)的父節(jié)點(diǎn))  node.removeChild(child)  
        tbody.removeChild(this.parentNode.parentNode)
    }
}
// for(var k in obj) {
//     k 得到的是屬性名
//     obj[k] 得到是屬性值
// }

實(shí)現(xiàn)效果:


點(diǎn)擊刪除按鈕,相應(yīng)的行會(huì)刪除。
點(diǎn)擊刪除“張三”的數(shù)據(jù):

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多