当前访客身份:游客 [ 登录 | 加入 OSCHINA ]

代码分享

当前位置:
代码分享 » JavaScript  » 网页设计与交互
分享到: 
收藏 +0
1
jQuery实现CheckBox全选、全不选
标签: jQuery

代码片段(1) [全屏查看所有代码]

1. [代码][JavaScript]代码     跳至 [1] [全屏预览]

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>jQuery实现CheckBox全选、全不选</title>
<script src="http://code.jquery.com/jquery-1.4.4.min.js" type="text/javascript"></script>    <script type="text/javascript">
        $(function() {
           $("#checkAll").click(function() {
                $('input[name="subBox"]').attr("checked",this.checked); 
            });
            var $subBox = $("input[name='subBox']");
            $subBox.click(function(){
				$("#checkAll").attr("checked",$subBox.length == $("input[name='subBox']:checked").length ? true : false);
            });
        });
    </script>

</head>
<body>
    <div>
        <input id="checkAll" type="checkbox" />全选
        <input name="subBox" type="checkbox" />项1
        <input name="subBox" type="checkbox" />项2
        <input name="subBox" type="checkbox" />项3
        <input name="subBox" type="checkbox" />项4
    </div>
</body>
</html>


开源中国-程序员在线工具:Git代码托管 API文档大全(120+) JS在线编辑演示 二维码 更多»

发表评论 回到顶部 网友评论(21)

  • 1楼:abd 发表于 2011-08-11 17:07 回复此评论
    这样简单些
    $('#CheckAll').click(function(){
        $('input[name="subBox"]').attr("checked",this.checked);
    });
  • 2楼:Archerfish 发表于 2011-08-11 18:26 回复此评论

    引用来自“plavip”的评论

    这样简单些
    $('#CheckAll').click(function(){
        $('input[name="subBox"]').attr("checked",this.checked);
    });
    正解!
  • 3楼:lovedreamland 发表于 2011-08-11 19:32 回复此评论

    引用来自“plavip”的评论

    这样简单些
    $('#CheckAll').click(function(){
        $('input[name="subBox"]').attr("checked",this.checked);
    });
    其实这样最终实现还是要去遍历,只是Jquery再次封装了一次而已。下面的代码是考虑到子项改变后父项的状态也随之改变。
  • 4楼:iuhoay 发表于 2011-08-18 08:57 回复此评论
    其实判断子项是不是全选这样简单些
    var $subBox = $("input[name='subBox']");
    
    document.getElementById("CheckAll").checked = ($subBox.length == $subBox.find(":checked").length ? true : false);
  • 5楼:lovedreamland 发表于 2011-08-18 21:05 回复此评论

    引用来自“charsky”的评论

    其实判断子项是不是全选这样简单些
    var $subBox = $("input[name='subBox']");
    
    document.getElementById("CheckAll").checked = ($subBox.length == $subBox.find(":checked").length ? true : false);
    多谢指教,可是我使用.find(":checked")方法的时候他始终查找不到已经被选中的checkbox的长度,一直都是0,不知道为什么。
  • 6楼:iuhoay 发表于 2011-08-19 05:40 回复此评论

    引用来自“lovedreamland”的评论

    引用来自“charsky”的评论

    其实判断子项是不是全选这样简单些
    var $subBox = $("input[name='subBox']");
    
    document.getElementById("CheckAll").checked = ($subBox.length == $subBox.find(":checked").length ? true : false);
    多谢指教,可是我使用.find(":checked")方法的时候他始终查找不到已经被选中的checkbox的长度,一直都是0,不知道为什么。
    // 完整的,上面写错了,应该用filter
    <script src="jquery-1.6.2.min.js"></script>


    <input type="checkbox" id="ckAll" />check all<br />
    <input type="checkbox" name="sub" />1<br />
    <input type="checkbox" name="sub"/>2<br />
    <input type="checkbox" name="sub"/>3<br />
    <input type="checkbox" name="sub"/>4<br />


    <script>

      $("#ckAll").click(function() {
        $("input[name='sub']").prop("checked", this.checked);
      });
      
      $("input[name='sub']").click(function() {
        var $subs = $("input[name='sub']");
        $("#ckAll").prop("checked" , $subs.length == $subs.filter(":checked").length ? true :false);
      });

    </script>
  • 7楼:lovedreamland 发表于 2011-08-19 14:49 回复此评论

    引用来自“charsky”的评论

    引用来自“lovedreamland”的评论

    引用来自“charsky”的评论

    其实判断子项是不是全选这样简单些
    var $subBox = $("input[name='subBox']");
    
    document.getElementById("CheckAll").checked = ($subBox.length == $subBox.find(":checked").length ? true : false);
    多谢指教,可是我使用.find(":checked")方法的时候他始终查找不到已经被选中的checkbox的长度,一直都是0,不知道为什么。
    // 完整的,上面写错了,应该用filter
    <script src="jquery-1.6.2.min.js"></script>


    <input type="checkbox" id="ckAll" />check all<br />
    <input type="checkbox" name="sub" />1<br />
    <input type="checkbox" name="sub"/>2<br />
    <input type="checkbox" name="sub"/>3<br />
    <input type="checkbox" name="sub"/>4<br />


    <script>

      $("#ckAll").click(function() {
        $("input[name='sub']").prop("checked", this.checked);
      });
      
      $("input[name='sub']").click(function() {
        var $subs = $("input[name='sub']");
        $("#ckAll").prop("checked" , $subs.length == $subs.filter(":checked").length ? true :false);
      });

    </script>
    多谢,收藏了~
  • 8楼:sxgkwei 发表于 2011-08-23 17:59 回复此评论
    <script type="text/javascript">
    $(function() {
    var all=$("#checkAll"), box= $("subBox");
    all.click(function(){
        box.attr("checked",this.checked);
    });
    box.click(function(){
        all.attr("checked":box.filter(": checked"). length?true:false );
    });
    </script>
  • 9楼:小乔流水 发表于 2011-12-15 15:09 回复此评论
    <script type="text/javascript">
    function CheckAll(val) { 
    $("input[name='chkJob']").each(function() { 
    this.checked = val; 
    }); 
    </script>


    <input type='checkbox' id='chkAll' onclick="CheckAll(this.checked)">checkAll<br> 
    <input name='chkJob' type='checkbox'>chk1<br> 
    <input name='chkJob' type='checkbox'>chk2<br> 
    <input name='chkJob' type='checkbox'>chk3<br> 
    <input name='chkJob' type='checkbox'>chk4<br> 


    这样最简单啦。。。



  • 10楼:Fly_f 发表于 2012-04-12 15:23 回复此评论
    好使
  • 11楼:Edwinn 发表于 2012-06-13 14:23 回复此评论
    测试了,确实好用,多谢
  • 12楼:2711694 发表于 2014-02-19 17:23 回复此评论

    引用来自“涂鸦”的评论

    <script type="text/javascript">
    function CheckAll(val) { 
    $("input[name='chkJob']").each(function() { 
    this.checked = val; 
    }); 
    </script>


    <input type='checkbox' id='chkAll' onclick="CheckAll(this.checked)">checkAll<br> 
    <input name='chkJob' type='checkbox'>chk1<br> 
    <input name='chkJob' type='checkbox'>chk2<br> 
    <input name='chkJob' type='checkbox'>chk3<br> 
    <input name='chkJob' type='checkbox'>chk4<br> 


    这样最简单啦。。。



    这个不错,each最好用
  • 13楼:小年纪大想法 发表于 2014-03-05 17:49 回复此评论

    引用来自“abd”的评论

    这样简单些
    $('#CheckAll').click(function(){
        $('input[name="subBox"]').attr("checked",this.checked);
    });
    这样的话第二次点击就不生效了
  • 14楼:Sucuri 发表于 2014-03-19 17:24 回复此评论
    最新jq版本下,代码使用有bug。
  • 15楼:Sucuri 发表于 2014-03-19 18:19 回复此评论
    改为
    $('#CheckAll').click(function(){ 
        $('input[name="subBox"]').prop("checked",this.checked); 
    });
    即可
  • 16楼:奋斗的海贼 发表于 2014-04-23 14:18 回复此评论

    引用来自“Sucuri”的评论

    改为
    $('#CheckAll').click(function(){ 
        $('input[name="subBox"]').prop("checked",this.checked); 
    });
    即可
    完全正确 我用的正是最新版
  • 17楼:哈妞妞 发表于 2014-08-09 13:09 回复此评论

    引用来自“lovedreamland”的评论

    引用来自“charsky”的评论

    引用来自“lovedreamland”的评论

    引用来自“charsky”的评论

    其实判断子项是不是全选这样简单些
    var $subBox = $("input[name='subBox']");
    
    document.getElementById("CheckAll").checked = ($subBox.length == $subBox.find(":checked").length ? true : false);
    多谢指教,可是我使用.find(":checked")方法的时候他始终查找不到已经被选中的checkbox的长度,一直都是0,不知道为什么。
    // 完整的,上面写错了,应该用filter
    <script src="jquery-1.6.2.min.js"></script>


    <input type="checkbox" id="ckAll" />check all<br />
    <input type="checkbox" name="sub" />1<br />
    <input type="checkbox" name="sub"/>2<br />
    <input type="checkbox" name="sub"/>3<br />
    <input type="checkbox" name="sub"/>4<br />


    <script>

      $("#ckAll").click(function() {
        $("input[name='sub']").prop("checked", this.checked);
      });
      
      $("input[name='sub']").click(function() {
        var $subs = $("input[name='sub']");
        $("#ckAll").prop("checked" , $subs.length == $subs.filter(":checked").length ? true :false);
      });

    </script>
    多谢,收藏了~
    正在查找这个方法,试用了,果然好用!非常感谢!收藏了!
  • 18楼:107822423 发表于 2014-08-26 12:35 回复此评论
    多谢 
      $("#ckAll").click(function() {
        $("input[name='sub']").prop("checked", this.checked);
      });
      
      $("input[name='sub']").click(function() {
        var $subs = $("input[name='sub']");
        $("#ckAll").prop("checked" , $subs.length == $subs.filter(":checked").length ? true :false);
      });
  • 19楼:develop_pan 发表于 2014-11-12 10:22 回复此评论
    朋友,但是如果子项全部选上了,那那个全选选项是不是应该也自动勾选上?
    可不可以帮忙实现一下,我很需要,谢谢你们了!
  • 20楼:dengkj 发表于 2014-12-15 16:14 回复此评论

    引用来自“develop_pan”的评论

    朋友,但是如果子项全部选上了,那那个全选选项是不是应该也自动勾选上?
    可不可以帮忙实现一下,我很需要,谢谢你们了!
    17楼收藏的方法就可以实现你要的效果。
开源从代码分享开始 分享代码
lovedreamland的其它代码 全部(3)...