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

学习笔记 2019/12/02 jQuery, JavaScript

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

 
 
 
 

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

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

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

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

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

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

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

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

方法④使用.each()遍历

$("input[type=checkbox]").each(function(){

if ($(this).attr("disabled") != "disabled") {

$(this).attr("checked",true);
}
});

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

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

    第一行 第二行 第三行
  • 第四行
  • 第五行 第六行
  • 第七行

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

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

结果是\'

  • 第二行
  • \'的背景变成了红色。使用了属性过滤选择器 [class=showli] 和基本过滤选择器 eq(0)

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

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

    结果是\'

  • 第六行
  • \'的背景变成了红色,display:block是为了检测隐藏的li是否会被:visible过滤,display:none下是看不到红色背景的。使用了可见性过滤选择器 :visible

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

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

    结果是\'

  • 第六行
  • \'的背景变成了红色。

    本文地址:https://www.stayed.cn/item/201

    转载请注明出处。

    本站部分内容来源于网络,如侵犯到您的权益,请 联系我

    我的博客

    人生若只如初见,何事秋风悲画扇。