jQuery 復合選擇器的幾個例子


<!-- 本文例子所引用的jQuery版本為 jQuery-1.8.3.min.js Author:博客園小dee -->

 

一. 復合選擇器對checkbox的相關操作

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

例.需要把類型為checkbox,同時"可用"的元素設置成"已選擇"

 

方法①使用屬性過濾選擇器 [type='checkbox'] 和 [disabled!=disabled]

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

在這個復合選擇器中,使用屬性過濾選擇器時"可用"元素的選擇應使用 disabled!=disabled,而設置屬性時可以使用 attr("checked",true)或attr("checked","checked")。

注意:在Jquery1.6以后,建議在設置disabled和checked這些屬性的時候使用prop()方法而不是用attr()方法。

 因此建議的寫法:

$("input[type='checkbox'][disabled!=disabled]").prop("checked",true);   //建議寫法

 

方法②使用表單選擇器 :checkbox 和屬性過濾選擇器 [disabled!=disabled]

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

 

方法③使用表單選擇器 :checkbox 和表單對象屬性過濾選擇器 :enabled

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

 

方法④使用.each()遍歷

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

在判斷屬性時attr()方法應該判斷是"disabled"還是"enable",而不是false或true。

 建議的寫法:

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

 

 

二. 復合選擇器的其他例子

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

 

例. 把第一個class為showli的li元素背景設為紅色

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

結果是'<li class="showli">第二行</li>'的背景變成了紅色。使用了屬性過濾選擇器 [class=showli] 和基本過濾選擇器 eq(0)

 

例. 把第五個可見的li的背景設為紅色

$("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的背景設成紅色

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

結果是'<li class="showli">第六行</li>'的背景變成了紅色。

 

作者: 小dee
說明:作者寫博目的是記錄開發過程,積累經驗,便於以后工作參考。
如需轉載,請在文章頁面保留此說明並且給出原文鏈接。謝謝!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM