• jQuery 复合选择器应用的几个例子


    这篇文章主要介绍了jQuery 复合选择器应用的几个例子,本文例子所引用的jQuery版本为 jQuery-1.8.3.min.js,喜欢的朋友可以学习下
     

    <!-- 本文例子所引用的jQuery版本为 jQuery-1.8.3.min.js -->

    一. 复合选择器对checkbox的相关操作

    1
    2
    3
    4
    5
    <input type="checkbox" id="ckb_1" /> 
    <input type="checkbox" id="ckb_2" disabled="true" /> 
    <input type="checkbox" id="ckb_3" /> 
    <input type="checkbox" id="ckb_4" /> 
    <input type="button" id="btn" value="点击">

    例.需要把类型为checkbox,同时"可用"的元素设置成"已选择"

    方法①使用属性过滤选择器 [type='checkbox'] 和 [disabled!=disabled]

    1
    $("input[type='checkbox'][disabled!=disabled]").attr("checked",true);

    注意在这个复合选择器中,"可用"元素的选择应使用 disabled!=disabled,而设置属性时应使用 attr("checked",true)。disabled属性和checked属性的用法类似。

    方法②使用表单选择器 :checkbox 和属性过滤选择器 [disabled!=disabled]

    1
    $('input:checkbox[disabled!=disabled]').attr("checked",true);

    方法③使用表单选择器 :checkbox 和表单对象属性过滤选择器 :enabled

    1
    $(':checkbox:enabled').attr("checked",true);

    方法④使用.each()遍历

    1
    2
    3
    4
    5
    6
    7
    $("input[type=checkbox]").each(function(){
      
    if ($(this).attr("disabled") != "disabled") {
      
    $(this).attr("checked",true);
    }
    });

    没用到复合选择器。需要注意的和方法①中一样,在判断属性时应该判断是"disabled"还是"enable",而不是false或true。而设置属性时既可以用"disabled"或"enable",也可以用false或true。

    二. 复合选择器的其他例子

    1
    2
    3
    4
    5
    6
    7
    8
    9
    <ul>
    <li >第一行</li>
    <li class="showli">第二行</li>
    <li class="showli">第三行</li>
    <li>第四行</li>
    <li style="display:none">第五行</li>
    <li class="showli">第六行</li>
    <li>第七行</li>
    </ul>

    例. 把第一个class为showli的li元素背景设为红色

    1
    $("ul li[class=showli]:eq(0)").css("background":"red");

    结果是'<li class="showli">第二行</li>'的背景变成了红色。使用了属性过滤选择器 [class=showli] 和基本过滤选择器 eq(0)

    例. 把第五个可见的li的背景设为红色

    1
    $("ul li:visible:eq(4)").css({"display":"blaock","background":"red"});

    结果是'<li class="showli">第六行</li>'的背景变成了红色,display:block是为了检测隐藏的li是否会被:visible过滤,display:none下是看不到红色背景的。使用了可见性过滤选择器 :visible

    例.(比较绕的)把第二个class为showli的li后面可见的第二个li的背景设成红色

    1
    $("ul li.showli:eq(1)").nextAll("li:visible:eq(1)").css({"display":"block","background":"red"});

    结果是'<li class="showli">第六行</li>'的背景变成了红色。

  • 相关阅读:
    python 进程、线程、协程感悟
    elk部署心得
    虚拟安装centos后无法上网、DNS无法解析问题解决
    mysql测试题
    爬取lol皮肤
    ping使用
    第一篇技术博客
    PADS layout修改字符时发生严重错误退出问题
    PADS 快捷键
    电容知识整理
  • 原文地址:https://www.cnblogs.com/gxlinhai/p/4263293.html
Copyright © 2020-2023  润新知