JavaScript動(dòng)態(tài)生成表格的示例
要求:
HTML標(biāo)簽只寫一行表頭
通過JS來寫動(dòng)態(tài)的表格(有多少組數(shù)據(jù),就自動(dòng)創(chuàng)建多少行表格)
為學(xué)習(xí)和演示,采用固定的數(shù)據(jù),不涉及調(diào)用后臺數(shù)據(jù)
代碼實(shí)現(xiàn):
HTML內(nèi)容:
<table cellspacing="0">
<thead>
<tr>
<th>姓名</th>
<th>科目</th>
<th>成績</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è)對象
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è)人(通過數(shù)組的長度)我們就創(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è)對象里面的屬性個(gè)數(shù) for循環(huán)遍歷對象 datas[i]
for (var k in datas[i]) { // 里面的for循環(huán)管列 td
// 創(chuàng)建單元格
var td = document.createElement('td');
// 把對象里面的屬性值 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:;" rel="external nofollow" >刪除</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ù):

以上就是JavaScript動(dòng)態(tài)生成表格的示例的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 生成表格的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序云開發(fā)實(shí)現(xiàn)微信支付功能業(yè)務(wù)邏輯可靠
這篇文章主要介紹了微信小程序云開發(fā)實(shí)現(xiàn)微信支付功能,云開發(fā)來開發(fā)微信小程序時(shí),如何實(shí)現(xiàn)微信支付,并且保證業(yè)務(wù)邏輯可靠,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2022-05-05
javascript 表格內(nèi)容排序 簡單操作示例代碼
本文為大家詳細(xì)介紹下javascript實(shí)現(xiàn)表格內(nèi)容排序,喜歡的朋友可以參考下2014-01-01
基于rem的移動(dòng)端響應(yīng)式適配方案(詳解)
下面小編就為大家?guī)硪黄趓em的移動(dòng)端響應(yīng)式適配方案(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
javascript 中按屬性值查找數(shù)組中的對象多種方法
JavaScript 數(shù)組可以保存混合類型的不同值,例如字符串、空值或布爾值,并且不需要數(shù)組的大小來指定它在哪里自動(dòng)增長和動(dòng)態(tài),這篇文章主要介紹了javascript 中按屬性值查找數(shù)組中的對象多種方法,需要的朋友可以參考下2023-06-06

