jQuery 遍歷- 關于closest() 的方法介紹以及與parents()的方法區(qū)別分析
closest() 方法獲得匹配選擇器的第一個祖先元素,從當前元素開始沿 DOM 樹向上。
語法:
.closest(selector)
參數(shù)selector為字符串值,包含匹配元素的選擇器表達式。
如果給定表示 DOM 元素集合的 jQuery 對象,.closest() 方法允許我們檢索 DOM 樹中的這些元素以及它們的祖先元素,并用匹配元素構造新的 jQuery 對象。.parents() 和 .closest() 方法類似,它們都沿 DOM 樹向上遍歷。兩者之間的差異盡管微妙,卻很重要:
.closest() | .parents() |
從當前元素開始 | 從父元素開始 |
沿 DOM 樹向上遍歷,直到找到已應用選擇器的一個匹配為止。 | 沿 DOM 樹向上遍歷,直到文檔的根元素為止,將每個祖先元素添加到一個臨時的集合;如果應用了選擇器,則會基于該選擇器對這個集合進行篩選。 |
返回包含零個或一個元素的 jQuery 對象 | 返回包含零個、一個或多個元素的 jQuery 對象 |
先看下面的示例:演示如何通過 closest() 完成事件委托。當被最接近的列表元素或其子后代元素被點擊時,會切換黃色背景
<!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、當鼠標點擊“You can also”時,顏色出現(xiàn)變化。這是因為closest是從當前元素開始向上遍歷的。而不同于parents()方法,是從當前元素的父元素開始向上遍歷。
2、當點擊Click me!時,顏色也會變化。這同樣經(jīng)過上面步驟,從當前元素向上匹配,只不過<b>不符合條件,再往上時遇見了<li>。
3、實例演示請訪問: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');
結果:
這會改變 level-2 <ul> 的顏色,這是因為當向上遍歷 DOM 樹時會第一個遇到該元素。
如下圖所示:
假設我們搜索的是 <li> 元素
$('li.item-a').closest('li').css('background-color', 'red');
這會改變列表項目 A 的顏色。在向上遍歷 DOM 樹之前,.closest() 方法會從 li 元素本身開始搜索,直到選擇器匹配項目 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');
以上代碼會改變 level-2 <ul> 的顏色,因為它既是列表項 A 的第一個 <ul> 祖先,同時也是列表項 II 的后代。
它不會改變 level-1 <ul> 的顏色,因為它不是 list item II 的后代。
相關文章
jQuery1.3.2 升級到jQuery1.4.4需要修改的地方
jQuery1.3.2 升級到 1.4.4 ,需要修改的地方,需要的朋友可以參考下。2011-01-01使用jquery的ajax需要注意的地方dataType的設置
沒有設置dataType:'json',就出現(xiàn)無法解析返回的data數(shù)據(jù),會把data當作字符串處理,而不是json對象,記得以前是不用設dataType的,很奇怪,不知道是不是跟jquery版本有關系2013-08-08jQuery實現(xiàn)對無序列表的排序功能(附demo源碼下載)
這篇文章主要介紹了jQuery實現(xiàn)對無序列表的排序功能,涉及jQuery與javascript常見的文本操作函數(shù)與sort排序函數(shù)的相關使用方法,具有一定參考借鑒價值,需要的朋友可以參考下2016-06-06基于JQuery的數(shù)字改變的動畫效果--可用來做計數(shù)器
之前用javascript做個計數(shù)器,從網(wǎng)上搜了搜,找不到合適的,就想著用jquery自己做一個2010-08-08