gpt4 book ai didi

javascript - 使用 createDocumentFragment 替换表中的现有列

转载 作者:行者123 更新时间:2023-11-30 12:42:26 27 4
gpt4 key购买 nike

我读到 createDocumentFragment 比在 for 循环中将元素一个一个地附加到 DOM 快得多,例如见here .

我想做什么:

  1. 在文档片段中创建一个表列。此列应包含数组中的数字(例如“评级”)。
  2. 之后,我想用新列(“片段”列)替换现有列。所以我可以一次性将整个列放入 DOM。

我的问题:

如果已有列,我真的不知道如何替换现有列。另一方面附加是没有问题的。

我的 JSfiddle:http://jsfiddle.net/LEqG9/2/

有用的链接,herehere

HTML

<table id = "table">
<tr>
<th>Name</th>
<th>Rating</th>
</tr>
<tr>
<td>A.H.Hattray </td>
<td id = "row0"></td>
</tr>
<tr>
<td>Icke_eben </td>
<td id = "row1"></td>
</tr>
<tr>
<td>John_Doe123 </td>
<td id = "row2"></td>
</tr>
</table>

Javascript

var rating = [1, 10, 3];
var fragment = document.createDocumentFragment();


for (var i = 0, len = rating.length; i < len; i++){
var element = document.createElement('tr');
element.innerHTML = rating[i];
fragment.appendChild(element);
}
document.getElementById('table').appendChild(fragment); //I know here should be the code to replace the second column!

最佳答案

以下代码演示了可以在 DocumentFragment 中操作现有表格。

var rating = [1, 10, 3];
var theTable = document.getElementById('table');
var frag = document.createDocumentFragment();
frag.appendChild(theTable);
var col2 = frag.querySelectorAll('tr td:nth-of-type(2)');
for (var i=0; i < col2.length; i++) {
col2[i].innerHTML = rating[i];
}
// it is also possible to use insertCell and deleteCell
var theRows = frag.querySelectorAll('tr');
for (var i=0; i < theRows.length; i++) {
var x = theRows[i].insertCell(1);
if (i > 0)
x.innerHTML = 'new one';
else
x.innerHTML = 'The Header';
}
document.body.appendChild(frag);

(使第一行中的新单元格成为 TH 元素,而不是 TD 需要更多工作,使用 createElementappendChildinsertBefore.)

如果您单步执行此操作,则表格在附加到片段时会从 DOM 中删除,然后在片段附加到正文时重新出现。

关于javascript - 使用 createDocumentFragment 替换表中的现有列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23942782/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com