jQuery 遍历 - closest() 方法
?
jQuery 遍歷參考手冊(cè)
實(shí)例
本例演示如何通過 closest() 完成事件委托。當(dāng)被最接近的列表元素或其子后代元素被點(diǎn)擊時(shí),會(huì)切換黃色背景:
$( document ).bind("click", function( e ) {$( e.target ).closest("li").toggleClass("hilight");});親自試一試
定義和用法
closest() 方法獲得匹配選擇器的第一個(gè)祖先元素,從當(dāng)前元素開始沿 DOM 樹向上。
語法
.closest(selector)| selector | 字符串值,包含匹配元素的選擇器表達(dá)式。 |
詳細(xì)說明
如果給定表示 DOM 元素集合的 jQuery 對(duì)象,.closest() 方法允許我們檢索 DOM 樹中的這些元素以及它們的祖先元素,并用匹配元素構(gòu)造新的 jQuery 對(duì)象。.parents()?和 .closest() 方法類似,它們都沿 DOM 樹向上遍歷。兩者之間的差異盡管微妙,卻很重要:
| 從當(dāng)前元素開始 | 從父元素開始 |
| 沿 DOM 樹向上遍歷,直到找到已應(yīng)用選擇器的一個(gè)匹配為止。 | 沿 DOM 樹向上遍歷,直到文檔的根元素為止,將每個(gè)祖先元素添加到一個(gè)臨時(shí)的集合;如果應(yīng)用了選擇器,則會(huì)基于該選擇器對(duì)這個(gè)集合進(jìn)行篩選。 |
| 返回包含零個(gè)或一個(gè)元素的 jQuery 對(duì)象 | 返回包含零個(gè)、一個(gè)或多個(gè)元素的 jQuery 對(duì)象 |
請(qǐng)看下面的 HTML 片段:
<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>例子 1
假設(shè)我們執(zhí)行一個(gè)從項(xiàng)目 A 開始的對(duì) <ul> 元素的搜索:
$('li.item-a').closest('ul').css('background-color', 'red');親自試一試
這會(huì)改變 level-2 <ul> 的顏色,這是因?yàn)楫?dāng)向上遍歷 DOM 樹時(shí)會(huì)第一個(gè)遇到該元素。
例子 2
假設(shè)我們搜索的是 <li> 元素:
$('li.item-a').closest('li').css('background-color', 'red');親自試一試
這會(huì)改變列表項(xiàng)目 A 的顏色。在向上遍歷 DOM 樹之前,.closest() 方法會(huì)從 li 元素本身開始搜索,直到選擇器匹配項(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');轉(zhuǎn)載于:https://www.cnblogs.com/kunlunmountain/p/5710811.html
總結(jié)
以上是生活随笔為你收集整理的jQuery 遍历 - closest() 方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Django中url匹配规则的补充
- 下一篇: 单节点部署Hadoop教程