我有一张table的信息。表的第一列有复选框。我可以通过选中复选框来使用按钮添加/删除行。我现在的问题是如何使用标题上的复选框选择或取消选择所有的复选框。
下面是我的代码:
<HTML>
<HEAD>
<TITLE> Add/Remove dynamic rows in HTML table </TITLE>
<SCRIPT language="javascript">
function addRow(tableID) {
var table = document.getElementById(tableID);
var rowCount = table.rows.length;
var row = table.insertRow(rowCount);
var cell1 = row.insertCell(0);
var element1 = document.createElement("input");
element1.type = "checkbox";
element1.name="chkbox[]";
cell1.appendChild(element1);
var cell2 = row.insertCell(1);
cell2.innerHTML = rowCount;
var cell3 = row.insertCell(2);
cell3.innerHTML = rowCount;
var cell4 = row.insertCell(3);
cell4.innerHTML = rowCount;
var cell5 = row.insertCell(4);
cell5.innerHTML = rowCount;
var cell6 = row.insertCell(5);
cell6.innerHTML = rowCount;
}
function deleteRow(tableID) {
try {
var table = document.getElementById(tableID);
var rowCount = table.rows.length;
for(var i=1; i<rowCount; i++) {
var row = table.rows[i];
var chkbox = row.cells[0].childNodes[0];
if(null != chkbox && true == chkbox.checked) {
table.deleteRow(i);
rowCount--;
i--;
}
}
}catch(e) {
alert(e);
}
}
function checkAll(formname, checktoggle)
{
var checkboxes = new Array();
checkboxes = document[formname].getElementsByTagName('input');
for (var i=0; i<checkboxes.length; i++) {
if (checkboxes[i].type == 'checkbox') {
checkboxes[i].checked = checktoggle;
}
}
}
</SCRIPT>
</HEAD>
<BODY>
<INPUT type="button" value="Add Row" onclick="addRow('dataTable')" />
<INPUT type="button" value="Delete Row" onclick="deleteRow('dataTable')" />
<TABLE id="dataTable" border="1">
<tr>
<th><INPUT type="checkbox" name="chk[]"/></th>
<th>Make</th>
<th>Model</th>
<th>Description</th>
<th>Start Year</th>
<th>End Year</th>
</tr>
</TABLE>
</BODY>
</HTML>
9条答案
按热度按时间g6ll5ycj1#
实际上你的**
checkAll(..)
挂着没有任何附件。1)添加
onchange
**事件处理程序2)修改代码以处理检查/取消检查
Updated Fiddle
ubbxdtey2#
JSBin
将onClick event添加到您想要的复选框中,如下所示。
在JavaScript中,你可以把 selectall 函数写成
bttbmeg03#
这将选中和取消选中所有复选框:
Demo
更新:
您可以直接在表格上使用querySelectAll来获取复选框列表,而不是搜索整个文档,但它可能与旧浏览器不兼容,因此您需要首先检查:
或者更具体地说,在OP问题中提供的html结构,在选择复选框时,这将更有效,因为它将直接访问它们而不是搜索它们:
Demo
xdyibdwo4#
这个解决方案更好,因为它更短,并且不使用循环。
id="checkAll"
是标题列tp5buhyn5#
选中所有复选框
$("input[type=checkbox]").prop('checked', true);
vhmi4jdf6#
aelbi1ox7#
fiddle
4jb9z9bj8#
这是一个只使用forEach()循环的JavaScript解决方案。我们将
Change
事件侦听器添加到主复选框中,然后使用checked
属性来检查是否需要选中/取消选中复选框。yb3bgrhw9#
试试这个: