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

浏览:751 发布日期:2018/12/13 分类:前端开发 关键字: jquery checkbox 全选 反选 全不选
jquery attr()方法获取标签的 checked 会有问题,所以用了 prop() 方法。
Hml的checkbox没有加name,只用了 div 嵌套。<div id="box">
    <input type="checkbox" value="1">西瓜
    <input type="checkbox" value="2">芒果
    <input type="checkbox" value="3">橙
    <input type="checkbox" value="4">山竹
    <input type="checkbox" value="5">草莓
    <input type="checkbox" value="6">火龙果
</div>           
<input type="checkbox" id="allChecked">全选
<input type="checkbox" id="invertChecked">反选
<input type="checkbox" id="orChecked">全选/反选/全不选

<script type="text/javascript">
//全选
$('#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);
     });
  }
});

//一键控制全选、反选、全不选
$('#orChecked').change(function(){
  if($(this).is(':checked')){
     var box = $('#box').children(':checkbox');
     if(box.length==box.filter(':not(:checked)').length){    // 复选框长度和没选中的个数一样 -> 全选 , .not(':checked').length 也可以。
     $('#box').children(':checkbox').prop('checked',true);
     }else{     // 如果有选中个数,-> 反选 
        $('#box').children(':checkbox').each(function(){     
           $(this).prop('checked',$(this).is(':checked')?false:true);
        });
      }
  }else{
      $('#box').children(':checkbox').prop('checked',false);    // 如控制键取消选中,剩余的checkbox也取消选中
  }
    
});
</script>
最佳答案
评论( 相关
后面还有条评论,点击查看>>