jQuery实现checkbox选项组全选,全不选,获取checkbox选项组的值

1.创建checkbox选项组

https://www.cnblogs.com/YorkZhangYang/p/12587827.html

 1.1checkbox选中状态通过checked属性判断,true为选中状态,false为取消选中状态

<input type="checkbox"  name="fruits"  value="苹果" checked="true">

1.2jQuery判断checkbox状态方法

prop()方法

 console.log($("input[name='fruits']:checkbox").prop("checked"));   

is()方法

console.log($("input[name='fruits']:checkbox").is(":checked"));  

1.3设置选中,取消选中

$("input[name='fruits']:checkbox").attr('checked',true);
$("input[name='fruits']:checkbox").attr('checked',false);

$("input[name='fruits']:checkbox").prop('checked',true);
$("input[name='fruits']:checkbox").prop('checked',false);

 

2.实现全选、全不选功能

   <script>
      $(function(){ 
          //单击全选框选中所有checkbox
      $("#checkAll").click(function(){
        if(this.checked)
        {
             $("input[type=checkbox]").prop("checked", true);
            //$("input[name='fruits']:checkbox").attr("checked",true);//使用attr方法第二次单击无法全选
        }
        else{
            $("input[name='fruits']").each(function(){
                $(this).prop("checked",false);
            });
        }  
      });      
      });
   </script>

3.获取checkbox的值

  //获取未选中checkbox的值
      var checkedList1 = new Array();
      $("input[type='checkbox']:not(:checked)").each(function(){
        checkedList1.push($(this).val());
      });
      //控制台输出
      checkedList1.forEach(function(val,index){console.log(val,index)});

   //获取已选中checkbox的值
    var checkedList2 = new Array();
      $("input[type='checkbox']:checked").each(function(){
        checkedList2.push($(this).val());
      });
      //控制台输出
      checkedList2.forEach(function(val,index){console.log(val,index)});
      });

 

4.效果图

 

 

注意:尽量不要用attr方法增加属性,否则会出现再次点击不生效的情况,用prop方法较好。

参考文章:

https://www.cnblogs.com/wangluochong/p/5579056.html

https://www.w3h5.com/post/109.html

https://blog.csdn.net/qq_32973061/article/details/81749906

https://blog.csdn.net/u011637069/article/details/51290164

 console.log($("input[name='fruits']:checkbox").prop("checked"));   
posted @ 2020-03-28 20:16  YorkShare  阅读(806)  评论(0编辑  收藏  举报