jQuery 遍歷- 關(guān)于closest() 的方法介紹以及與parents()的方法區(qū)別分析
closest() 方法獲得匹配選擇器的第一個(gè)祖先元素,從當(dāng)前元素開(kāi)始沿 DOM 樹(shù)向上。
語(yǔ)法:
.closest(selector)
參數(shù)selector為字符串值,包含匹配元素的選擇器表達(dá)式。
如果給定表示 DOM 元素集合的 jQuery 對(duì)象,.closest() 方法允許我們檢索 DOM 樹(shù)中的這些元素以及它們的祖先元素,并用匹配元素構(gòu)造新的 jQuery 對(duì)象。.parents() 和 .closest() 方法類似,它們都沿 DOM 樹(shù)向上遍歷。兩者之間的差異盡管微妙,卻很重要:
| .closest() | .parents() |
| 從當(dāng)前元素開(kāi)始 | 從父元素開(kāi)始 |
| 沿 DOM 樹(shù)向上遍歷,直到找到已應(yīng)用選擇器的一個(gè)匹配為止。 | 沿 DOM 樹(shù)向上遍歷,直到文檔的根元素為止,將每個(gè)祖先元素添加到一個(gè)臨時(shí)的集合;如果應(yīng)用了選擇器,則會(huì)基于該選擇器對(duì)這個(gè)集合進(jìn)行篩選。 |
| 返回包含零個(gè)或一個(gè)元素的 jQuery 對(duì)象 | 返回包含零個(gè)、一個(gè)或多個(gè)元素的 jQuery 對(duì)象 |
先看下面的示例:演示如何通過(guò) closest() 完成事件委托。當(dāng)被最接近的列表元素或其子后代元素被點(diǎn)擊時(shí),會(huì)切換黃色背景
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<style>
li { margin: 3px; padding: 3px; background: #EEEEEE; }
li.hilight { background: yellow; }
</style>
</head>
<body>
<ul>
<li><b>Click me!</b></li>
<li>You can also <b>Click me!</b></li>
</ul>
<script>
$( document ).bind("click", function( e ) {
$( e.target ).closest("li").toggleClass("hilight");
});
</script>
</body>
</html>
1、當(dāng)鼠標(biāo)點(diǎn)擊“You can also”時(shí),顏色出現(xiàn)變化。這是因?yàn)閏losest是從當(dāng)前元素開(kāi)始向上遍歷的。而不同于parents()方法,是從當(dāng)前元素的父元素開(kāi)始向上遍歷。
2、當(dāng)點(diǎn)擊Click me!時(shí),顏色也會(huì)變化。這同樣經(jīng)過(guò)上面步驟,從當(dāng)前元素向上匹配,只不過(guò)<b>不符合條件,再往上時(shí)遇見(jiàn)了<li>。
3、實(shí)例演示請(qǐng)?jiān)L問(wèn):http://www.w3school.com.cn/tiy/t.asp?f=jquery_traversing_closest
例2:
<ul id="one" class="level-1">
<li class="item-i">I</li>
<li id="ii" class="item-ii">II
<ul class="level-2">
<li class="item-a">A</li>
<li class="item-b">B
<ul class="level-3">
<li class="item-1">1</li>
<li class="item-2">2</li>
<li class="item-3">3</li>
</ul>
</li>
<li class="item-c">C</li>
</ul>
</li>
<li class="item-iii">III</li>
</ul>
$('li.item-a').closest('ul').css('background-color', 'red');
結(jié)果:
這會(huì)改變 level-2 <ul> 的顏色,這是因?yàn)楫?dāng)向上遍歷 DOM 樹(shù)時(shí)會(huì)第一個(gè)遇到該元素。
如下圖所示:

假設(shè)我們搜索的是 <li> 元素
$('li.item-a').closest('li').css('background-color', 'red');
這會(huì)改變列表項(xiàng)目 A 的顏色。在向上遍歷 DOM 樹(shù)之前,.closest() 方法會(huì)從 li 元素本身開(kāi)始搜索,直到選擇器匹配項(xiàng)目 A 為止。
例子 3
我們可以傳遞 DOM 元素作為 context(即限定搜索的最大范圍),在其中搜索最接近的元素。
var listItemII = document.getElementById('ii');
$('li.item-a').closest('ul', listItemII).css('background-color', 'red');
$('li.item-a').closest('#one', listItemII).css('background-color', 'green');
以上代碼會(huì)改變 level-2 <ul> 的顏色,因?yàn)樗仁橇斜眄?xiàng) A 的第一個(gè) <ul> 祖先,同時(shí)也是列表項(xiàng) II 的后代。
它不會(huì)改變 level-1 <ul> 的顏色,因?yàn)樗皇?list item II 的后代。
相關(guān)文章
jquery中插件實(shí)現(xiàn)自動(dòng)添加用戶的具體代碼
當(dāng)點(diǎn)擊添加時(shí)自動(dòng)彈出窗口,填寫完畢按確定自動(dòng)添加到table表格中,有需要的朋友可以參考一下2013-11-11
jQuery實(shí)現(xiàn)的動(dòng)態(tài)伸縮導(dǎo)航菜單實(shí)例
這篇文章主要介紹了jQuery實(shí)現(xiàn)的動(dòng)態(tài)伸縮導(dǎo)航菜單,實(shí)例分析了jQuery鼠標(biāo)事件及animate、hide等方法的使用技巧,需要的朋友可以參考下2015-05-05
jquerymobile局部渲染的各種刷新方法小結(jié)
本篇文章主要是對(duì)jquerymobile局部渲染的各種刷新方法進(jìn)行了總結(jié)介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-03-03
EasyUI學(xué)習(xí)之Combobox級(jí)聯(lián)下拉列表(2)
這篇文章主要為大家詳細(xì)介紹了EasyUI學(xué)習(xí)之Combobox級(jí)聯(lián)下拉列表的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
jQuery插件slides實(shí)現(xiàn)無(wú)縫輪播圖特效
Slides – 是一個(gè)簡(jiǎn)單的,容易定制和風(fēng)格化,的jQuery幻燈片插件。Slides提供褪色或幻燈片過(guò)渡效果,圖像淡入淡出,圖像預(yù)壓,自動(dòng)生成分頁(yè),循環(huán),自動(dòng)播放的自定義等很多選項(xiàng)。用Slides插件,你可以隨機(jī)播放幻燈片,設(shè)定那一套您想要開(kāi)始幻燈片。2015-04-04
jquery實(shí)現(xiàn)刷新隨機(jī)變化樣式特效(tag標(biāo)簽樣式)
本文主要介紹了tag標(biāo)簽隨機(jī)多彩變化的超鏈接樣式,使用JQ+DIV+CSS實(shí)現(xiàn)刷新隨機(jī)變化樣式特效。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
jQuery實(shí)現(xiàn)簡(jiǎn)單的輪播圖效果
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)簡(jiǎn)單的輪播圖效果,實(shí)現(xiàn)自動(dòng)播放,能手動(dòng)切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
基于jquery的一行代碼輕松實(shí)現(xiàn)拖動(dòng)效果
寫JS實(shí)現(xiàn)拖動(dòng)需要一大堆不便維護(hù)的代碼,實(shí)屬麻煩,Google了大半天,發(fā)現(xiàn)了一個(gè)優(yōu)秀的Jquery插件EasyDrag,只需要一行代碼便可輕松在主流瀏覽器上。2010-12-12
jQuery源碼分析之jQuery.fn.each與jQuery.each用法
這篇文章主要介紹了jQuery源碼分析之jQuery.fn.each與jQuery.each用法,較為詳細(xì)的分析了each的用法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-01-01

