我已经为此努力了一段时间。我有一个基于某些JSON数据自动生成的表,该数据可能会有所不同。我想合并第一列中具有相同值的相邻单元格,例如此表中的“鱼”和“鸟”:
<table>
<tr>
<td>fish</td>
<td>salmon</td>
</tr>
<tr>
<td>fish</td>
<td>cod</td>
</tr>
<tr>
<td>fish</td>
<td>plaice</td>
</tr>
<tr>
<td>bird</td>
<td>robin</td>
</tr>
<tr>
<td>bird</td>
<td>crow</td>
</tr>
</table>
我不想理想地使用任何库,仅使用纯JS。
这就是我想要的样子:
table, tr, td {
border: solid 1px black;
}
<table>
<tr>
<td rowspan="3">fish</td>
<td>salmon</td>
</tr>
<tr>
<td>cod</td>
</tr>
<tr>
<td>plaice</td>
</tr>
<tr>
<td rowspan="2">bird</td>
<td>robin</td>
</tr>
<tr>
<td>crow</td>
</tr>
</table>
我一直在寻找不同的方法来识别不同的值及其频率,然后将行距更改为正确的数字,然后删除其他单元格,但是在不同的用例中,所有这些单元格都崩溃了。
这是我到目前为止所拥有的:
let table = document.querySelector('table');
let rowCount = 1;
for (let i = 0; i < (table.rows.length - 1); i++) {
if (table.rows[i].cells[0].innerHTML === table.rows[i + 1].cells[0].innerHTML) {
rowCount++;
} else if (rowCount !== 1) {
table.rows[i].cells[0].setAttribute('rowspan', rowCount);
for (let j = (i - rowCount + 1); j < rowCount; j++) {
table.rows[j].cells[0].remove();
};
rowCount = 1;
};
};
table, tr, td {
border: solid 1px black;
}
<table>
<tr>
<td>fish</td>
<td>salmon</td>
</tr>
<tr>
<td>fish</td>
<td>cod</td>
</tr>
<tr>
<td>fish</td>
<td>plaice</td>
</tr>
<tr>
<td>bird</td>
<td>robin</td>
</tr>
<tr>
<td>bird</td>
<td>crow</td>
</tr>
</table>
这根本不是我想要的,但我觉得我真的很亲密!它试图计算下面的一个具有相同值的(第一列)单元格的数量,将此数字分配给最后一个相关单元格的行跨度,然后删除随后的单元格,然后循环返回以捕获其余单元格。我希望我的最终代码是这种代码的变体,所以有人可以告诉我我要去哪里了吗?非常感谢!
答案 0 :(得分:0)
您确实非常接近!
一种简化的方法是保留对当前“标头”单元格的引用,即您要增加其rowspan
的单元格。这样,您根本不必处理索引,从而产生了一个非常简单的算法:
对于每一行
如果这是第一行,或者 firstCell 的文本不同于 headerCell 的文本
在JavaScript中,它看起来像这样:
const table = document.querySelector('table');
let headerCell = null;
for (let row of table.rows) {
const firstCell = row.cells[0];
if (headerCell === null || firstCell.innerText !== headerCell.innerText) {
headerCell = firstCell;
} else {
headerCell.rowSpan++;
firstCell.remove();
}
}
table, tr, td {
border: solid 1px black;
}
<table>
<tr>
<td>fish</td>
<td>salmon</td>
</tr>
<tr>
<td>fish</td>
<td>cod</td>
</tr>
<tr>
<td>fish</td>
<td>plaice</td>
</tr>
<tr>
<td>bird</td>
<td>robin</td>
</tr>
<tr>
<td>bird</td>
<td>crow</td>
</tr>
</table>