in the following table:
<table>
<thead>
<tr>
<th>Th1</th>
<th colspan='2'>Th23</th>
<th>Th4</th>
</tr>
</thead>
<tbody>
<tr>
<td>Td1</td>
<td>Td2</td>
<td>Td3</td>
<td>Td4</td>
</tr>
</tbody>
</table>
For the table cell containing text “Th23”, I’d like to know which cells reside beneath it. In this case, the answer would be the cells containing text “Td2”, and “Td3” respectively.
Are there any DOM properties or built-ins that help with this type of calculation?
@Matt McDonald has a more general solution.
This is what I ended up with:
// get tbody cell(s) under thead cell (first arg)
// if rowIndex===undefined, get from all rows; otherwise, only that row index
// NOTE: does NOT work if any cell.rowSpan != 1
var columnCells = function( th, rowIndex ) {
// get absolute column for th
for( var absCol=0, i=0; true; i++ ) {
if( th.parentNode.cells[i] == th ) break;
absCol += th.parentNode.cells[i].colSpan;
}
// look in tBody for cells; all rows or rowIndex
var tBody = th.parentNode.parentNode.nextSibling;
var cells = [];
for( var r=((rowIndex==undefined)?0:rowIndex); true; r++ ) {
if( rowIndex!==undefined && r>rowIndex ) break;
if( rowIndex==undefined && r>=tBody.rows.length ) break;
for( var c=0; true; c+=tBody.rows[r].cells[c].colSpan ) {
if( c < absCol ) continue;
if( c >= absCol+th.colSpan ) break;
cells.push(tBody.rows[r].cells[c]);
}
}
return cells;
}
Right off the bat, you need to do three things:
idattribute for easy selection.idattribute for easy selection as well.parentNode(row)These three things will enable easier table-related calculations.
Next up is a function that grabs pseudo-properties of the specified cell. In this case, we’re looking for its “start index” (in terms of columns), its “end index” (in terms of columns), and its “width” (end – start, in columns as well).
From there, you can traverse through the table’s rows and check which cells fall between the start and the end indexes.
HTML:
JS (bear with me):
Demo: http://jsbin.com/ohohew/edit#javascript,html
This will determine which cells reside inside the particular column you’re looking for (including the example). You can customize the function to fit your needs if that’s not exactly what you’re looking for.