首頁  >  文章  >  web前端  >  jQuery查找和過濾實例詳解

jQuery查找和過濾實例詳解

小云云
小云云原創
2018-01-06 09:05:321307瀏覽

通常情況下選擇器可以直接定位到我們想要的元素,但是,當我們拿到一個jQuery物件後,還可以以這個物件為基準,進行尋找和篩選。本文主要為大家詳細介紹了jQuery查找和過濾的相關資料,具有一定的參考價值,有興趣的小夥伴們可以參考一下,希望能幫助大家。

最常見的查找是在某個節點的所有子節點中查找,使用find()方法,它本身又接收一個任意的選擇器。例如如下的HTML結構:


<!-- HTML结构 -->
<ul class="lang">
 <li class="js dy">JavaScript</li>
 <li class="dy">Python</li>
 <li id="swift">Swift</li>
 <li class="dy">Scheme</li>
 <li name="haskell">Haskell</li>
</ul>

find()#

var ul = $(&#39;ul.lang&#39;); // 获得<ul>
var dy = ul.find(&#39;.dy&#39;); // 获得JavaScript, Python, Scheme
var swf = ul.find(&#39;#swift&#39;); // 获得Swift
var hsk = ul.find(&#39;[name=haskell]&#39;); // 获得Haskell


var swf = $(&#39;#swift&#39;); // 获得Swift
var parent = swf.parent(); // 获得Swift的上层节点<ul>
var a = swf.parent(&#39;p.red&#39;); // 从Swift的父节点开始向上查找,直到找到某个符合条件的节点并返回

如果要從目前節點開始往上查找,使用

parent()方法:


var swift = $(&#39;#swift&#39;);

swift.next(); // Scheme
swift.next(&#39;[name=haskell]&#39;); // Haskell,因为Haskell是后续第一个符合选择器条件的节点

swift.prev(); // Python
swift.prev(&#39;.js&#39;); // JavaScript,因为JavaScript是往前第一个符合选择器条件的节点

對於位於同一層級的節點,可以透過

next()prev()方法,例如:當我們已經拿到
Swift節點後:


##和函數式程式設計的map、filter類似,jQuery物件也有類似的方法。

filter()


方法可以過濾掉不符合選擇器條件的節點:##

var langs = $(&#39;ul.lang li&#39;); // 拿到JavaScript, Python, Swift, Scheme和Haskell
var a = langs.filter(&#39;.dy&#39;); // 拿到JavaScript, Python, Scheme

或者傳入一個函數,要特別注意函數內部的

this

被綁定為DOM對象,不是jQuery物件:

##

var langs = $(&#39;ul.lang li&#39;); // 拿到JavaScript, Python, Swift, Scheme和Haskell
langs.filter(function () {
 return this.innerHTML.indexOf(&#39;S&#39;) === 0; // 返回S开头的节点
}); // 拿到Swift, Scheme

map()


方法把一個jQuery物件包含的若干DOM節點轉換成其他物件:

var langs = $(&#39;ul.lang li&#39;); // 拿到JavaScript, Python, Swift, Scheme和Haskell
var arr = langs.map(function () {
 return this.innerHTML;
}).get(); // 用get()拿到包含string的Array:[&#39;JavaScript&#39;, &#39;Python&#39;, &#39;Swift&#39;, &#39;Scheme&#39;, &#39;Haskell&#39;]
此外,一個jQuery物件如果包含了不只一個DOM節點,

first()、last()


slice()方法可以回傳一個新的jQuery對象,把不需要的DOM節點去掉:

var langs = $(&#39;ul.lang li&#39;); // 拿到JavaScript, Python, Swift, Scheme和Haskell
var js = langs.first(); // JavaScript,相当于$(&#39;ul.lang li:first-child&#39;)
var haskell = langs.last(); // Haskell, 相当于$(&#39;ul.lang li:last-child&#39;)
var sub = langs.slice(2, 4); // Swift, Scheme, 参数和数组的slice()方法一致
相關推薦:

##詳解PHP實作尋找兩個陣列中不同元素的方法


php在多維數組中尋找指定值的方法

PHP二分法實現數組查找功能教程

以上是jQuery查找和過濾實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn