Jquery 实现智能全选(new)

 

做页面一直会遇到全选和全不选的问题,在网上什么一句话实现全选全不选,也有很多用js方法实现的。

但是好像都忽略了一个问题,全选的可以控制下面的列表,但是下面的列表不能控制上面的全选,所以我就写了个例子

思路,一个全选checkALl,其他为checkItem,如果checkAll,全选和全不选下面的checkItem肯定也是全不选

  但是如果checkItem为有一个没有勾选,checkAll就不应该勾选,如果checkItem全勾选上,checkAll应该要变为是勾选上的

ok,看看我实现的效果吧 

把以下代码直接保存为htm文件就可以看到效果

再看看实现过程

<!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>
    <title></title>
</head>
<body>
<script src="http://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.8.0.js">
    </script>
    <script type="text/javascript">
        $(document).ready(function () {

            $("#checkAll").click(function () {
                $(".checkItem").attr("checked", $(this)[0].checked);
                 })

            $(".checkItem").click(function () {
                var objs = $(".checkItem");
                var isAllChecked = true; //是否是全選
                for (var i = 0; i < objs.length; i++) {
                    if (!objs[i].checked) {
                        isAllChecked = false;
            break;
                    }
                }
             $("#checkAll").attr("checked", isAllChecked); 

            }
            );

        });
    </script>
    <input type="checkbox" id="checkAll" />
    全選
    <div>
        <input type="checkbox" class="checkItem" />
        1<br />
        <input type="checkbox" class="checkItem" />
        2<br />
        <input type="checkbox" class="checkItem" />
        3<br />
        <input type="checkbox" class="checkItem" />
        4<br />
    </div>
</body>
</html>

 

有以下几点需要注意

1:为什么全选时转为$(this)[0].checked DOM元素,我在查看别人利用的$(this).attr("checked")来决定勾选是发现不选上时是无效的,因为其为未定义的

2:其实只需判断是否为全选,如果有一个没有勾上,Checkall应该是不勾上,当全部勾上时才是全勾上

 

提问:我想把这个方法写为公用的方法,使页面上有多组checkbox时每组可以单独使用,但是找不到区分的方法,这个有待更新,希望有大神可以给点思路。

 

後面我又想到了简单的方法,如下,利用选择的长度来判断,比原来的循环强

    <script type="text/javascript">
        $(document).ready(function () {

            $("#checkAll").click(function () {
                $(".checkItem").attr("checked", $(this)[0].checked);
            })

            $(".checkItem").click(function () {
                var IAll = $(".checkItem").length;//全部數目
                var IChk = $(".checkItem:checked").length;//勾選的數目
                var isAllChecked = true; //是否是全選
                if (IAll != IChk) {
                    isAllChecked = false;
                }
                $("#checkAll").attr("checked", isAllChecked);
            }
            );

        });
    </script>

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。