jQuery实现全选、全不选以及反选操作

更新日期: 2018-12-09阅读量: 1960标签: jquery

在写购物车案例时实现全选操作使用的是js的getAttribute()setAttribute()方法获取checked属性的值是undefined实现完成之后全选操作,如果在全选中的情况下改变其中一个的状态再点击全选,之前被取消的将不在被选中。之后使用js的DOM.checked属相的获得是true或false,操作很方便,很完美没有bug。


学了jquery后单独实现下全选、全不选、反选操作。代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <h3>我的爱好</h3>
    <ul>
        <li>
            <input type="checkbox" class="sAll"/>全选 <input type="checkbox" class="sNone"/>全不选 
            <input type="checkbox" class="Inverse"/>反选 
        </li>
        <li><input type="checkbox" class="check"/>篮球</li>
        <li><input type="checkbox" class="check"/>足球</li>
        <li><input type="checkbox" class="check"/>排球</li>
        <li><input type="checkbox" class="check"/>羽毛球</li>
        <li><input type="checkbox" class="check"/>乒乓球</li>
        
    </ul>
    <script src="jquery.js"></script>
    <script>
        /*全选*/
        //1.拿到全选复选框的jquery对象调用change(),当前对象的状态改变时进行下面操作
        $('.sAll').change(function () {
            //2.拿到所有class属相值为check的对象,将其checked属性值设置为true。
            $('.check').attr('checked',true);

            //点击全选,全不选、反选其中一个时其它两的选中状态清除
            $('.sNone').attr('checked',false);
            $('.Inverse').attr('checked',false);
        });
        //alert($('.sAll').attr('checked'));
        /*全不选*/
        $('.sNone').change(function () {
            $('.check').attr('checked',false);
            
            //点击全选,全不选、反选其中一个时其它两的选中状态清除
            $('.sAll').attr('checked',false);
            $('.Inverse').attr('checked',false);
        });
        /*反选*/
        //注意:attr()方法取第一个的值 ,赋值所用
        $('.Inverse').change(function () {
            //遍历所有要操作的复选框
            $('.check').each(function () {
                //如果该复选框的checked属性为true,则改为false,反之为true
                if($(this).attr('checked')){
                    $(this).attr('checked',false);
                }else{
                    $(this).attr('checked',true);
                }
               
            });
            //将全选和全不选的状态去掉(点击全选,全不选、反选其中一个时其它两的选中状态清除)
            $('.sAll').attr('checked',false);
            $('.sNone').attr('checked',false);
        });
    </script>
</body>
</html>


来源:https://www.cnblogs.com/wang--yang/archive/2018/12/09/10091303.html



站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: https://www.fly63.com/article/detial/1527

jquery实现点击控制div的显示和隐藏

我们使用点击显示、点击隐藏的时候,一般有两种可选方案,toggle() 的作用就是当对象是显示的就隐藏,当是隐藏的则显示

利用jQuery not()方法选取除某个元素外的所有元素

日常的工作中可能会用到,选取处某个或者某些元素外的所有元素。这时我们可以使用 jQuery 遍历中的 not() 方法来排除某些元素,例如根据元素的 #id ,.class 等排除,代码如下:

前端UI攻城狮 你们该抛弃jQuery了

Web工程师太依赖jQuery了,某种意义上说jQuery已经成了JavaScript的同义词。但是我们真的需要他么?或许我们应该反思一下什么时候才真的需要jQuery。对我个人而言开始使用jQuery的理由是他把我的工作变得简单多了

jquery checkbox选中、改变状态、change和click事件

jquery判断checked的三种方法:jquery赋值checked的几种写法:jquery1.6+:prop的4种赋值:checkbox click和change事件

前端jquery防止数据重复提交

前端在向后端进行数据提交的时候,通常会需要在第一次提交返回前,阻止用户在快速点击发送二次请求,即防止重复提交,最简单的方法是使用标志参数或者 class 元素控制

前端程序员应该知道的15个jQuery小技巧

15个jQuery小技巧:返回顶部按钮,预加载图像,检查图像是否加载,自动修复破坏的图像,悬停切换类,禁用输入字段,停止加载链接,淡入/滑动切换,简单的手风琴...

原生js中DOM对象转成jQuery对象、jQuery 对象转成 DOM 对象的实现

jquery是对js语言的封装、扩展,实现了对浏览器的兼容,使用jquery能让操作更方便简洁,这篇文章主要讲解原生js中Dom对象和jquery对象的相互转换。

jquery设置属性attr

jquery中用attr()方法来获取和设置元素属性,attr是attribute(属性)的缩写,在jQuery DOM操作中会经常用到attr(),attr()有4个表达式。attr(属性名)、attr(属性名, 属性值)、attr(属性名,函数值)、attr(properties)

jQuery如何为指定标签添加和删除一个样式

在网页的实际应用中,需要根据不同的条件来改变元素的CSS样式,通过动态的给元素添加删除一个CSS类可以实现此功能,下面通过实例来介绍一下如何实现此种功能。

高版本jquery中attr和prop的区别

在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?对于HTML元素本身就带有的固有属性,在处理时,使用prop方法。对于HTML元素我们自己自定义的DOM属性,在处理时,使用attr方法。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!