首頁 >web前端 >js教程 >如何用jQuery取得父級和父級以上的元素

如何用jQuery取得父級和父級以上的元素

yulia
yulia原創
2018-09-18 15:28:594646瀏覽

jquery在前端開發中運用廣泛,可以用jQuery取得子元素,父元素,兄弟元素等等,這篇文章就和大家講講如何用jQuery獲取父元素和父元素以上的元素,有需要的朋友可以看看,希望對你有用。

parent(),parents(),closest()這些方法都能實現查找父元素或節點

先有個範例:

<ul class="parent1">
  <li><a href="#" id="item1">jquery获取父节点</a></li> 
  <li><a href="#">jquery获取父元素</a></li> 
</ul>

我們的目的是透過id 為item1 的便條a取到class 為parent1 的ul元素,有以下幾種方法:

1、parent([expr])

取得一個包含著所有符合元素的唯一父元素的元素集合。
例如:

$(&#39;#item1&#39;).parent().parent(&#39;.parent1&#39;);

2、:parent

#符合含有子元素或文字的元素

$(&#39;li:parent&#39;);

3、parents( [expr])

取得一個包含所有符合元素的祖先元素的元素集合(不包含根元素)。可以透過一個可選的表達式進行篩選。

$(&#39;#items&#39;).parents(&#39;.parent1&#39;);

4、closest([expr])

closest會先檢查當前元素是否匹配,如果匹配則直接傳回元素本身。如果不符合則向上尋找父元素,一層一層往上,直到找到符合選擇器的元素。如果什麼都沒找到則回傳一個空的jQuery物件。

closest和parents的主要區別是:1,前者從當前元素開始匹配尋找,後者從父元素開始匹配尋找;2,前者逐級向上查找,直到發現匹配的元素後就停止了,後者一直向上查找直到根元素,然後把這些元素放進一個臨時集合中,再用給定的選擇器表達式去過濾;3,前者返回0或1個元素,後者可能包含0 個, 1個,或者多個元素。

closest對於處理事件委派非常有用。

$(&#39;#items1&#39;).closest(&#39;.parent1&#39;);

以上是如何用jQuery取得父級和父級以上的元素的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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