在表格或者列表中经常会遇到要全选或者反选等交互,今天总结了一下代码,保留着以后直接拿来用
原理:
1. 全选:当全选checkbox被点击(不管点击之前是什么状态)后,获取其checked状态。然后对列表进行循环检测,此时可以将所有的(无论之前什么状态),设为选中,也可对未选中的进行选中。
2. 反选:当反选checkbox被点击(不管点击之前是什么装填)后,获取其其状态值,对列表进行循环检测,将被检测的元素的checked状态反向处理,即可。
3. 列表全选或者不全选:当列表中的任意一个checkbox被点击,侧应该对列表中的所有checkbox进行循环检测,如果此时全部选中,则应将全选checked选中,如果有至少一个没被选中,则应将全选checkbox取消选中。
代码实现:
为了测试代码的正确性,建立如下的HTML文档:
<!DOCTYPE html>
<html>
<head>
<title>checkbox测试</title>
</head>
<body>
<table>
<tr>
<td><input type="checkbox" id="allChecked"><span>全选</span></td>
<td><input type="checkbox" id="antiChecked"><span>全选</span></td>
</tr>
<tr>
<td><input type="checkbox" class="sonChecked"></td>
<td>1</td>
</tr>
<tr>
<td><input type="checkbox" class="sonChecked"></td>
<td>2</td>
</tr>
<tr>
<td><input type="checkbox" class="sonChecked"></td>
<td>3</td>
</tr>
</tr>
<td><input type="checkbox" class="sonChecked"></td>
<td>4</td>
</tr>
<tr>
<td><input type="checkbox" class="sonChecked"></td>
<td>5</td>
</tr>
</table>
</body>
</html>
//全选(id="allChecked") 反选(id="antiChecked") 选项列表(class="sonChecked") 选择使用id,class, name等属性作为选择器都可以,根据自己的文档来确定。
//javascript代码(原生的)
//条件检测,兼容性
if(!document.getElementById) return;
var allCheck = document.getElementById('allChecked');
var antiCheck = document.getElementById('antiChecked');
//条件检测,兼容性
if(!document.getElementsByClassName) return;
var sonChecks = document.getElementsByClassName('sonChecked');
//全选操作
allCheck.click = function(){
var allCheckState = allCheck.checked;
for(var i = 0;i<listChecks.length; i++){
if(listChecks[i].checked!=allCheckState){
listChecks[i].click();
}
}
}
//反选操作
antiCheck.click= function(){
for(var i = 0;i<listChecks.length;i++){
listChecks[i].click();
}
}
//列表项行为
for(var i = 0;i<listChecks.length;i++){
listChecks[i].click= function(){
for(var i=0;i<listChecks.length;i++){
if(!listChecks[i].checked){
allCheck.checked = false;
return;
}
}
allCheck.checked = true;
}
}
//也可以将这几个方法直接封装成函数,然后传入参数,直接调用,但如果是这样的话不建议在HTML里面使用 onchange="function(A,B)"之类的,应该将javascript与HTML分离。