本文實例總結了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])
取得一個包含所有符合元素的唯一父元素的元素集合。
你可以使用可選的表達式來篩選。
程式碼如下
$('#item1').parent().parent('.parent1');
2、:parent
符合含有子元素或文字的元素
程式碼如下
$('li:parent');
3、parents([expr])
取得一個包含所有符合元素的祖先元素的元素集合(不包含根元素)。可以透過一個可選的表達式進行篩選。
程式碼如下
$('#items').parents('.parent1');
4、closest([expr])
closest會先檢查當前元素是否匹配,如果匹配則直接傳回元素本身。如果不符合則向上尋找父元素,一層一層往上,直到找到符合選擇器的元素。如果什麼都沒找到則回傳一個空的jQuery物件。
closest和parents的主要區別是:
① 前者從目前元素開始配對尋找,後者從父元素開始配對尋找;
② 前者逐級向上查找,直到發現匹配的元素後就停止了,後者一直向上查找直到根元素,然後把這些元素放進一個臨時集合中,再用給定的選擇器表達式去過濾;
③ 前者回傳0或1個元素,後者可能包含0 個,1個,或多個元素。
closest對於處理事件委派非常有用。
$('#items1').closest('.parent1');
更多關於jQuery相關內容有興趣的讀者可查看本站專題:《jQuery遍歷演算法與技巧總結》、《jQuery表格(table)操作技巧總結》 、《jQuery拖曳特效與技巧總結》、《jQuery擴充技巧總結》、《jQuery常見經典特效總結》、《