使用jquery獲取父元素或父節點的方法


jquery獲取父元素方法比較多,比如parent(),parents(),closest()這些都能幫你實現查找父元素或節點,下面我們來一一講解:

先舉個例子,

1.<ul class="parent1">

  2. <li><a href="#" id="item1">jquery獲取父節點</a></li>
  3. <li><a href="#">jquery獲取父元素</a></li>
  4. </ul>

 

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

1、parent([expr])

取得一個包含着所有匹配元素的唯一父元素的元素集合。

你可以使用可選的表達式來篩選。

代碼如下

1.$('#item1').parent().parent('.parent1');

2、:parent

匹配含有子元素或者文本的元素

代碼如下

 

  1. $('li:parent'); 

3、parents([expr])

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

代碼如下

   1.$('#items').parents('.parent1');

  4、closest([expr])

closest會首先檢查當前元素是否匹配,如果匹配則直接返回元素本身。如果不匹配則向上查找父元素,一層一層往上,直到找到匹配選擇器的元素。如果什么都沒找到則返回一個空的jQuery對象。

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

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

1. $('#items1').closest('.parent1');


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM