最近开发项目时遇到一个很奇怪的问题,就是checkbox的全选与全不选
使用jquery的框架。一直是使用
//检测选中的checkbox
$('input[name="abc"]:checked').each(function(){})
但是,发现我需要全选的时候,使用
$('input[name="abc"]').attr('checked',true);
$('input[name="abc"]').attr('checked',false);
时,第一次加载的时候管用,再次点击就只显示它自己了
但是点击的时候,查看源代码,属性checked已经添加上了
百思不得其解,最后搜索到,原来是 attr属性 对于checked来说
他不会使dom样式改变,只会将它的属性值改变,jquery提供了取而代之的方法,如下就可以了
$('input[name="abc"]').prop('checked',true);
$('input[name="abc"]').prop('checked',false);
但是,问题又来了,不全选时我检测不到哪个元素被点击了,然后就在name上做文章
$('input[name="abc[]:checked"').each(function(i){});
//或者
$('input[name="abc[]"').each(function(i){
var flag = $(this).prop('checked');
if(flag){
//$(this) 即为选中元素
}
})
令我苦恼的是,问题虽然解决了,但是,我不明白为什么要将所有的name属性都改成"abc[]",而且 html中对应的name也要改成 "abc[]",如有大神,欢迎评论交流。谢谢。