zoukankan      html  css  js  c++  java
  • 实现checkbox全选、非全选、单选

    全局选择与单选有以下两点关系:

    1、当我把所有单选都选择上的时候,全选应该是被选择状态

    2、当我取消一个单选时,全选应该是取消的状态

    如果不存在全局选择与单选之间的关系,则会出现如下两图情况:

     代码实现:(为了更清晰方便,所以只有复选框,可以根据自己需要进行修改)

    <div>
      <ul>
        <li> 
          <!--全选-->
          <input type="checkbox" id="all" class="parent_check">全选</li>
      </ul>
    </div>
    <div class="dataBox">
      <ul >
        <li >
          <input type="checkbox" id="checkbox_1" class="son_check">
        </li>
      </ul>
      <ul >
        <li >
          <input type="checkbox" id="checkbox_2" class="son_check">
        </li>
      </ul>
    <div>
    $(function () {
        //全局的checkbox选中和未选中的样式
        $parentChexbox = $('.parent_check'), //全选
        $dataBox = $('.dataBox'),            //用于判断全局与子类的关系
        $sonCheckBox = $('.son_check');      //单个子类选中
     
        //全局全选与单个的关系
        $parentChexbox.click(function () {
            var $checkboxs = $dataBox.find('input[type="checkbox"]');
            if ($(this).is(':checked')) {
                $checkboxs.prop("checked", true);
            } else {
                $checkboxs.prop("checked", false);
            }
        });
        
        $sonCheckBox.each(function () {
            $(this).click(function () {
                if ($(this).is(':checked')) {
                    //判断:所有单个是否勾选
                    var len = $sonCheckBox.length;
                    var num = 0;
                    $sonCheckBox.each(function () {
                        if ($(this).is(':checked')) {
                            num++;
                        }
                    });
                    if (num == len) {
                        $parentChexbox.prop("checked", true);
                    }
                } else {
                    //单个取消勾选,全局全选取消勾选
                    $parentChexbox.prop("checked", false);
                }
            })
        })
    });
  • 相关阅读:
    win7 配置DNS
    链表效率
    链表用途&&数组效率&&链表效率&&链表优缺点
    java 生成随机数字
    汉诺塔
    利用HTML5开发Android(1)---Android设备多分辨率的问题
    Android读取assets目录下的资源
    Ubuntu 搭建PHP开发环境
    关于heritrix安装配置时出现”必须限制口令文件读取访问权限”的解决方法
    JQuery 的bind和unbind函数
  • 原文地址:https://www.cnblogs.com/xiaoniuniu886/p/11527620.html
Copyright © 2011-2022 走看看