zoukankan      html  css  js  c++  java
  • 复选框使用总结

    对复选框最基本的应用, 就是对复选框进行全选,反选和全不选等操作.复杂的操作需要与选项挂钩,来达到各种级联效果.
    首先在空白网页中创建一个表单, 其中放入一组复选框:
     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Title</title>
     6 </head>
     7 <body>
     8 <form action="">
     9     你爱好的运动是?<br/>
    10     <input type="checkbox" name="items" value="足球"/>足球
    11     <input type="checkbox" name="items" value="篮球"/>篮球
    12     <input type="checkbox" name="items" value="羽毛球"/>羽毛球
    13     <input type="checkbox" name="items" value="兵乓球"/>兵乓球
    14     <input type="checkbox" name="items" value="排球"/>排球<br/>
    15     <input type="button" id="CheckedAll" value="全选"/>
    16     <input type="button" id="CheckedNo" value="全不选"/>
    17     <input type="button" id="CheckedRev" value="反选"/>
    18     <input type="button" id="send" value="提交">
    19 </form>
    20 <script type="text/javascript" src="js/jquery-1-8-3.js"></script>
    21 <script type="text/javascript">
    22     $(function () {
    23         //全选
    24         $("#CheckedAll").click(function () {
    25             $("[name = items]:checkbox").attr("checked",true);
    26         });
    27         //全不选
    28         $("#CheckedNo").click(function () {
    29             $("[name = items]:checkbox").attr("checked",false);
    30         });
    31         //反选
    32         /***
    33          * 反选需要循环每一个复选框进行设置,取他们值得反值.
    34          */
    35         $("#CheckedRev").click(function () {
    36             $("[name = items]:checkbox").each(function(){
    37                 $(this).attr("checked",!$(this).attr("checked"));
    38             });
    39         });
    40         /***
    41          * 此处用jQuery的attr()方法来设置属性checked的有些复杂,如果改用javascript原生的DOM方法,将比jQuery对象更有效和简洁.
    42          */
    43         $("#CheckedRev").click(function () {
    44             $("[name = items]:checkbox").each(function(){
    45                this.checked = !this.checked;
    46             });
    47         });
    48         /***
    49          * 复选框选中后,用户单机提交按钮, 需要将选中的项的值输出.可以通过val()方法获取选中的值.
    50          */
    51         $("#send").click(function () {
    52             var str = "你选中的是:
    ";
    53             $("[name = items]:checkbox:checked").each(function(){
    54                 str += $(this).val() + "
    ";
    55             });
    56             console.log(str);
    57         });
    58     });
    59 </script>
    60 </body>
    61 </html>

    效果截图:

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Title</title>
     6 </head>
     7 <body>
     8 <form action="">
     9     你爱好的运动是?<br/>
    10     <input type="checkbox" id="CheckedAll"/>全选/全不选<br/>
    11     <input type="checkbox" name="items" value="足球"/>足球
    12     <input type="checkbox" name="items" value="篮球"/>篮球
    13     <input type="checkbox" name="items" value="羽毛球"/>羽毛球
    14     <input type="checkbox" name="items" value="兵乓球"/>兵乓球
    15     <input type="checkbox" name="items" value="排球"/>排球<br/>
    16     <input type="button" id="send" value="提交">
    17 </form>
    18 <script type="text/javascript" src="js/jquery-1-8-3.js"></script>
    19 <script type="text/javascript">
    20     $(function () {
    21         //全选
    22 //        $("#CheckedAll").click(function () {//如果当前单机的复选框被选中
    23 //            if(this.checked){
    24 //                $("[name = items]:checkbox").attr("checked",true);
    25 //            }else{
    26 //                $("[name = items]:checkbox").attr("checked",false);
    27 //            }
    28 //        });
    29 
    30         /***
    31          * 所有复选框的checked属性的值和控制全选的复选框的checked属性的值是相同的, 因此可以省略if判断,直接赋值
    32          */
    33 
    34 //        $("#CheckedAll").click(function () {//如果当前单机的复选框被选中
    35 //            $("[name = items]:checkbox").attr("checked",this.checked);
    36 //        });
    37 
    38         /***
    39          * 当单机id为CheckedAll的复选框后, 复选框组被选中.
    40          * 当复选框组里取消某一个选项的选中状态, id为CheckedAll的复选框并没有被取消选中状态.
    41          * 而此时需要它和复选框能够联系起来,即复选框组里如果有一个或者更多没选中时,则取消d为CheckedAll的复选框的选中状态.
    42          * 如果复选框组被选中时,则d为CheckedAll的复选框也自动被选中.
    43          * 因此需要对复选框组进行操作, 以通过他们来控制d为CheckedAll的复选框.
    44          * (1)对复选框组绑定单击事件.
    45          * (2)定义一个flag变量, 默认为true
    46          * (3)循环复选框组, 当有没被选中的项时,则把变量flag的值设置为false.
    47          * (4)根军变量flag的值来设置id为CheckedAll的复选框是否选中.
    48          */
    49 
    50         $("#CheckedAll").click(function () {//如果当前单机的复选框被选中
    51             $("[name = items]:checkbox").attr("checked",this.checked);
    52         });
    53 //        $("[name = items]:checkbox").click(function () {
    54 //            var flag = true;
    55 //            $("[name = items]:checkbox").each(function () {
    56 //                if(!this.checked){
    57 //                    flag = false;
    58 //                }
    59 //            });
    60 //            $("#CheckedAll").attr("checked", flag);
    61 //        });
    62         /***
    63          * 另一种办法
    64          * (1)对复选框绑定单击事件
    65          * (2)判断复选框的总数是否与选中复选框数量相等.
    66          * (3)如果相等,则说明全部选中,否则不选中.
    67          */
    68         $("[name = items]:checkbox").click(function () {
    69             //定义一个临时变量, 避免重复使用同一个选择器选择页面中的元素, 提高程序效率
    70             var $tmp = $("[name = items]:checkbox");
    71             //用filter()方法筛选出选中的复选框,并直接给CheckedAll赋值
    72             $("#CheckedAll").attr("checked", $tmp.length == $tmp.filter(":checked").length);
    73         });
    74 
    75         $("#send").click(function () {
    76             var str = "你选中的是:
    ";
    77             $("[name = items]:checkbox:checked").each(function(){
    78                 str += $(this).val() + "
    ";
    79             });
    80             console.log(str);
    81         });
    82     });
    83 </script>
    84 </body>
    85 </html>

    下过截图:

  • 相关阅读:
    _00020 妳那伊抹微笑_谁的异常最诡异第一期之 SqlServer RSA premaster secret error
    &lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第12章 | 图形用户界面
    ubuntu 14.04 桌面版关闭图形界面
    (一)简单工厂模式
    JS学习笔记-数据类型
    【C#】报表制作&lt;机房重构&gt;
    [leetcode][math] Add Digits
    hibernate(三) 一对多映射关系
    hibernate(二)一级缓存和三种状态解析
    Hibernate(五)之一对多&多对一映射关系
  • 原文地址:https://www.cnblogs.com/liubeimeng/p/5896059.html
Copyright © 2011-2022 走看看