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ù)組形式儲存,每個(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)文章
利用百度地圖JSAPI生成h7n9禽流感分布圖實(shí)現(xiàn)代碼
本文將詳細(xì)介紹下如何使用百度地圖JSAPI生成的H7N9感染分布圖,有對百度api感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04通過javascript進(jìn)行UTF-8編碼的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄ㄟ^javascript進(jìn)行UTF-8編碼的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06javascript實(shí)現(xiàn)連續(xù)賦值
javascript如何實(shí)現(xiàn)連續(xù)賦值呢?下面小編就給大家介紹下用javascript實(shí)現(xiàn)連續(xù)賦值,有需要的朋友可以參考下2015-08-08詳解JavaScript中的執(zhí)行上下文及調(diào)用堆棧
這篇文章主要介紹了JavaScript中的執(zhí)行上下文及調(diào)用堆棧,對此感興趣的同學(xué),可以參考下2021-04-04javascript 隱藏/顯示指定的區(qū)域附HTML元素【legend】用法
今日閑來無事就寫寫JS,用來顯示/隱藏制定的DIV區(qū)域。2010-03-03