【发布时间】:2017-08-28 17:55:40
【问题描述】:
我是 javascript 新手,但我遇到了一段时间无法解决的问题... 我需要即时对表格进行排序。 (借用的)代码是:
function sortTable(n) {
var table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0;
table = document.getElementById("myTable2");
switching = true;
dir = "asc";
while (switching) {
switching = false;
rows = table.getElementsByTagName("TR");
for (i = 1; i < (rows.length - 1); i++) {
shouldSwitch = false;
x = rows[i].getElementsByTagName("TD")[n];
y = rows[i + 1].getElementsByTagName("TD")[n];
if (dir == "asc") {
if (x.innerHTML.toLowerCase() > y.innerHTML.toLowerCase()) {
shouldSwitch= true;
break;
}
} else if (dir == "desc") {
if (x.innerHTML.toLowerCase() < y.innerHTML.toLowerCase()) {
shouldSwitch= true;
break;
}
}
}
if (shouldSwitch) {
rows[i].parentNode.insertBefore(rows[i + 1], rows[i]);
switching = true;
switchcount ++;
} else {
if (switchcount == 0 && dir == "asc") {
dir = "desc";
switching = true;
}
}
}
}
它适用于文本/数值,但问题是表中的一列包含复选框。想法是按照带有选中复选框的行在顶部(/底部,取决于升序/降序方向)的方式对表格进行排序。
我尝试检查 x.innerHTML.checked==true,但 x.innerHTML.checked 返回“未定义”,因此没有任何用处。
有什么建议吗?
【问题讨论】:
标签: javascript html checkbox