JavaScript動態生成表格


要求:

  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] 得到是屬性值
// }

實現效果:


點擊刪除按鈕,相應的行會刪除。
點擊刪除“張三”的數據:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM