jQuery 復(fù)合選擇器應(yīng)用的幾個(gè)例子
<!-- 本文例子所引用的jQuery版本為 jQuery-1.8.3.min.js -->
一. 復(fù)合選擇器對(duì)checkbox的相關(guān)操作
<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="點(diǎn)擊">
例.需要把類型為checkbox,同時(shí)"可用"的元素設(shè)置成"已選擇"
方法①使用屬性過(guò)濾選擇器 [type='checkbox'] 和 [disabled!=disabled]
$("input[type='checkbox'][disabled!=disabled]").attr("checked",true);
注意在這個(gè)復(fù)合選擇器中,"可用"元素的選擇應(yīng)使用 disabled!=disabled,而設(shè)置屬性時(shí)應(yīng)使用 attr("checked",true)。disabled屬性和checked屬性的用法類似。
方法②使用表單選擇器 :checkbox 和屬性過(guò)濾選擇器 [disabled!=disabled]
$('input:checkbox[disabled!=disabled]').attr("checked",true);
方法③使用表單選擇器 :checkbox 和表單對(duì)象屬性過(guò)濾選擇器 :enabled
$(':checkbox:enabled').attr("checked",true);
方法④使用.each()遍歷
$("input[type=checkbox]").each(function(){ if ($(this).attr("disabled") != "disabled") { $(this).attr("checked",true); } });
沒(méi)用到復(fù)合選擇器。需要注意的和方法①中一樣,在判斷屬性時(shí)應(yīng)該判斷是"disabled"還是"enable",而不是false或true。而設(shè)置屬性時(shí)既可以用"disabled"或"enable",也可以用false或true。
二. 復(fù)合選擇器的其他例子
<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>
例. 把第一個(gè)class為showli的li元素背景設(shè)為紅色
$("ul li[class=showli]:eq(0)").css("background":"red");
結(jié)果是'<li class="showli">第二行</li>'的背景變成了紅色。使用了屬性過(guò)濾選擇器 [class=showli] 和基本過(guò)濾選擇器 eq(0)
例. 把第五個(gè)可見(jiàn)的li的背景設(shè)為紅色
$("ul li:visible:eq(4)").css({"display":"blaock","background":"red"});
結(jié)果是'<li class="showli">第六行</li>'的背景變成了紅色,display:block是為了檢測(cè)隱藏的li是否會(huì)被:visible過(guò)濾,display:none下是看不到紅色背景的。使用了可見(jiàn)性過(guò)濾選擇器 :visible
例.(比較繞的)把第二個(gè)class為showli的li后面可見(jiàn)的第二個(gè)li的背景設(shè)成紅色
$("ul li.showli:eq(1)").nextAll("li:visible:eq(1)").css({"display":"block","background":"red"});
結(jié)果是'<li class="showli">第六行</li>'的背景變成了紅色。
相關(guān)文章
Jquery實(shí)現(xiàn)無(wú)刷新DropDownList聯(lián)動(dòng)實(shí)現(xiàn)代碼
隨著Jquery1.4的發(fā)布,Jquery運(yùn)用越來(lái)越多了,讓我們來(lái)實(shí)現(xiàn)以前經(jīng)常用到的DropDownList無(wú)刷新聯(lián)動(dòng)。2010-03-03使用JQuery 加載頁(yè)面時(shí)調(diào)用JS的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇使用JQuery 加載頁(yè)面時(shí)調(diào)用JS的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05jQuery彈出窗口簡(jiǎn)單實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了jQuery彈出窗口的簡(jiǎn)單實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03JQEasy-ui在IE9以下版本中二次加載的問(wèn)題分析及處理方法
之前項(xiàng)目中才用了Easy-ui,但是在同時(shí)使用tree和grid的效果時(shí),因?yàn)轫?yè)面有倆個(gè)URL,分別為Ajax樹(shù)去后臺(tái)取數(shù)據(jù)和Grid取數(shù)據(jù),在IE9以上以及其他瀏覽器里都沒(méi)有問(wèn)題,在Ie低版本時(shí)會(huì)出現(xiàn)先加載表格,然后一閃而過(guò)加載樹(shù)渲染頁(yè)面,造成頁(yè)面只有tree數(shù)據(jù)而沒(méi)有表格grid數(shù)據(jù)。2014-06-06servlet+jquery實(shí)現(xiàn)文件上傳進(jìn)度條示例代碼
現(xiàn)在文件的上傳,特別是大文件上傳,都需要進(jìn)度條。這篇文章主要介紹了servlet+jquery實(shí)現(xiàn)文件上傳進(jìn)度條示例代碼,有興趣的可以了解一下。2017-01-01jQuery中通過(guò)ajax的get()函數(shù)讀取頁(yè)面的方法
這篇文章主要介紹了jQuery中通過(guò)ajax的get()函數(shù)讀取頁(yè)面的方法,需要的朋友可以參考下2016-02-02jQuery實(shí)現(xiàn)彩帶延伸效果的網(wǎng)頁(yè)加載條loading動(dòng)畫(huà)
這篇文章主要介紹了jQuery實(shí)現(xiàn)彩帶延伸效果的網(wǎng)頁(yè)加載條loading動(dòng)畫(huà),涉及jQuery動(dòng)畫(huà)效果的實(shí)現(xiàn)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-10-10