jquery一键控制checkbox全选,反选,全不选。

本文介绍使用jQuery实现复选框全选、反选及全不选功能的方法。通过监听控制按钮的状态改变来更新一组复选框的状态,采用prop()方法确保正确设置checked属性。

jquery attr()方法获取标签的 checked 会有问题,所以用了 prop() 方法。

Hml的checkbox没有加name,只用了 div 嵌套。

如有更好的方法,望指点!!

//全选
$('#allChecked').change(function(){
     $('#box').children(':checkbox').prop('checked',$(this).is(':checked')?true:false);
});
//反选
$('#invertChecked').change(function(){
  if($(this).is(':checked')){
     $('#box').children(':checkbox').each(function(){
       $(this).prop('checked',$(this).is(':checked')?false:true);
     });
  }
});
 1 //一键控制全选、反选、全不选
 2 $('#orChecked').change(function(){
 3   if($(this).is(':checked')){
 4      var box = $('#box').children(':checkbox');
 5      if(box.length==box.filter(':not(:checked)').length){    // 复选框长度和没选中的个数一样 -> 全选 , .not(':checked').length 也可以。
 6      $('#box').children(':checkbox').prop('checked',true);
 7      }else{     // 如果有选中个数,-> 反选 
 8         $('#box').children(':checkbox').each(function(){     
 9            $(this).prop('checked',$(this).is(':checked')?false:true);
10         });
11   }else{
12       $('#box').children(':checkbox').prop('checked',false);    // 如控制键取消选中,剩余的checkbox也取消选中
13   }
14     
15 });    
 1 <div align="center">
 2           
 3       <div id="box">
 4           <input type="checkbox" value="1">西瓜
 5           <input type="checkbox" value="2">芒果
 6           <input type="checkbox" value="3"> 7           <input type="checkbox" value="4">山竹
 8           <input type="checkbox" value="5">草莓
 9           <input type="checkbox" value="6">火龙果
10       </div>    
11               
12       <br>
13               
14       <input type="checkbox" id="allChecked">全选
15       <input type="checkbox" id="invertChecked">反选
16       <input type="checkbox" id="orChecked">全选/反选/全不选
17               
18   </div>

 

如有更好的方法,望指点!!

转载于:https://www.cnblogs.com/nmnm/p/7676103.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值