jQuery 复合选择器应用的几个例子
<!--本文例子所引用的jQuery版本为jQuery-1.8.3.min.js-->
一.复合选择器对checkbox的相关操作
<inputtype="checkbox"id="ckb_1"/> <inputtype="checkbox"id="ckb_2"disabled="true"/> <inputtype="checkbox"id="ckb_3"/> <inputtype="checkbox"id="ckb_4"/> <inputtype="button"id="btn"value="点击">
例.需要把类型为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。
二.复合选择器的其他例子
<ul> <li>第一行</li> <liclass="showli">第二行</li> <liclass="showli">第三行</li> <li>第四行</li> <listyle="display:none">第五行</li> <liclass="showli">第六行</li> <li>第七行</li> </ul>
例.把第一个class为showli的li元素背景设为红色
$("ulli[class=showli]:eq(0)").css("background":"red");
结果是'<liclass="showli">第二行</li>'的背景变成了红色。使用了属性过滤选择器[class=showli]和基本过滤选择器eq(0)
例.把第五个可见的li的背景设为红色
$("ulli:visible:eq(4)").css({"display":"blaock","background":"red"});
结果是'<liclass="showli">第六行</li>'的背景变成了红色,display:block是为了检测隐藏的li是否会被:visible过滤,display:none下是看不到红色背景的。使用了可见性过滤选择器:visible
例.(比较绕的)把第二个class为showli的li后面可见的第二个li的背景设成红色
$("ulli.showli:eq(1)").nextAll("li:visible:eq(1)").css({"display":"block","background":"red"});
结果是'<liclass="showli">第六行</li>'的背景变成了红色。