关于checkbox的全选问题

最近开发项目时遇到一个很奇怪的问题,就是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[]",如有大神,欢迎评论交流。谢谢。
                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值