我有使用以下js生成的表:
var tbl = document.createElement('table');
var tbdy = document.createElement('tbody');
var thd = document.createElement('thead');
var Headings = ["Lun","File","CDROM","Removable","ReadOnly","NoFUA"];
var tr = document.createElement('tr');
for (var i = 0; i < Headings.length; i++) {
var td = document.createElement('td');
td.appendChild(document.createTextNode(Headings[i]))
tr.appendChild(td);
}
thd.appendChild(tr);
for (var lun in data) {
console.log(lun);
var tr = document.createElement('tr');
tr.appendChild(document.createElement('td').appendChild(document.createTextNode(lun)));
for (var info in data[lun]) {
var td = document.createElement('td');
td.appendChild(document.createTextNode(data[lun][info]))
tr.appendChild(td)
}
tbdy.appendChild(tr);
}
tbl.appendChild(thd);
tbl.appendChild(tbdy);
var table = document.getElementById('file-table');
以及以下相关HTML:
<table id="file-table" style="width:100%"></table>
您在js的最后一行中看到的appendChild
方法有效,但是使用js创建表的目的是完全替换'file-table'
的所有childNodes。
我尝试遍历childNodes并使用removeChild
方法,但这会产生一些有趣的结果-不会完全删除所有节点,或者有时会出现有关第一个参数不是Node的错误消息。
有什么想法吗?
您能否选择目标元素并直接更新它们?
document.getElementById('td1').innerHTML = "Some text to enter"
如果没有,您也可以replace the table body本身:
var new_tbody = document.createElement('tbody');
populate_with_new_rows(new_tbody);
old_tbody.parentNode.replaceChild(new_tbody, old_tbody)