jquery獲取父元素方法比較多,好比parent(),parents(),closest()這些都能幫你實現查找父元素或節點,下面咱們來一一講解:jquery
先舉個例子:spa
<ul class="parent1"> <li><a href="#" id="item1">jquery獲取父節點</a></li> <li><a href="#">jquery獲取父元素</a></li> </ul>
咱們的目的是經過 id 爲 item1 的便籤a取到 class 爲 parent1 的ul元素,有如下幾種方法:code
一、parent([expr])對象
取得一個包含着全部匹配元素的惟一父元素的元素集合。blog
你可使用可選的表達式來篩選。事件
代碼以下it
$('#item1').parent().parent('.parent1');
二、:parentclass
匹配含有子元素或者文本的元素方法
代碼以下:集合
$('li:parent');
三、parents([expr])
取得一個包含着全部匹配元素的祖先元素的元素集合(不包含根元素)。能夠經過一個可選的表達式進行篩選。
代碼以下:
$('#items').parents('.parent1');
四、closest([expr])
closest會首先檢查當前元素是否匹配,若是匹配則直接返回元素自己。若是不匹配則向上查找父元素,一層一層往上,直到找到匹配選擇器的元素。若是什麼都沒找到則返回一個空的jQuery對象。
closest和parents的主要區別是:1,前者從當前元素開始匹配尋找,後者從父元素開始匹配尋找;2,前者逐級向上查找,直到發現匹配的 元素後 就中止了,後者一直向上查找直到根元素,而後把這些元素放進一個臨時集合中,再用給定的選擇器表達式去過濾;3,前者返回0或1個元素,後者可能包含0 個,1個,或者多個元素。
closest對於處理事件委派很是有用。
$('#items1').closest('.parent1');