JavaScript動態生成表格的示例
要求:
HTML標簽只寫一行表頭通過JS來寫動態的表格(有多少組數據,就自動創建多少行表格)為學習和演示,采用固定的數據,不涉及調用后臺數據
代碼實現: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:;' 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() { // 點擊a刪除 當前a所在的行(a父節點的父節點) node.removeChild(child) tbody.removeChild(this.parentNode.parentNode) }}// for(var k in obj) {// k 得到的是屬性名// obj[k] 得到是屬性值// }
實現效果:
點擊刪除按鈕,相應的行會刪除。點擊刪除“張三”的數據:
以上就是JavaScript動態生成表格的示例的詳細內容,更多關于JavaScript 生成表格的資料請關注好吧啦網其它相關文章!
相關文章: