jquery獲取父元素方法比較多,好比parent(),parents(),closest()這些都能幫你實現查找父元素或節點,下面咱們來一一講解:jquery
先舉個例子,spa
1.
<
ul
class
=
"parent1"
>
code
2.
<
li
><
a
href
=
"#"
id
=
"item1"
>jquery獲取父節點</
a
></
li
>
orm
3.
<
li
><
a
href
=
"#"
>jquery獲取父元素</
a
></
li
>
對象
4.
</
ul
>
事件
咱們的目的是經過 id 爲 item1 的便籤a取到 class 爲 parent1 的ul元素,有如下幾種方法:it
一、parent([expr])class
取得一個包含着全部匹配元素的惟一父元素的元素集合。import
你可使用可選的表達式來篩選。方法
代碼以下
1.
$(
'#item1'
).parent().parent(
'.parent1'
);
二、:parent
匹配含有子元素或者文本的元素
代碼以下
1.
$(
'li:parent'
);
三、parents([expr])
取得一個包含着全部匹配元素的祖先元素的元素集合(不包含根元素)。能夠經過一個可選的表達式進行篩選。
代碼以下
1.
$(
'#items'
).parents(
'.parent1'
);
四、closest([expr])
closest會首先檢查當前元素是否匹配,若是匹配則直接返回元素自己。若是不匹配則向上查找父元素,一層一層往上,直到找到匹配選擇器的元素。若是什麼都沒找到則返回一個空的jQuery對象。
closest和parents的主要區別是:1,前者從當前元素開始匹配尋找,後者從父元素開始匹配尋找;2,前者逐級向上查找,直到發現匹配的元素後 就中止了,後者一直向上查找直到根元素,而後把這些元素放進一個臨時集合中,再用給定的選擇器表達式去過濾;3,前者返回0或1個元素,後者可能包含0 個,1個,或者多個元素。
closest對於處理事件委派很是有用。
1.
$(
'#items1'
).closest(
'.parent1'
);
JQUERY的父,子,兄弟節點查找方法
jQuery.parent(expr) 找父親節點,能夠傳入expr進行過濾,好比$("span").parent()或者$("span").parent(".class")
jQuery.parents(expr),相似於jQuery.parents(expr),可是是查找全部祖先元素,不限於父元素
jQuery.children(expr).返回全部子節點,這個方法只會返回直接的孩子節點,不會返回全部的子孫節點
jQuery.contents(),返回下面的全部內容,包括節點和文本。這個方法和children()的區別就在於,包括空白文本,也會被做爲一個
jQuery對象返回,children()則只會返回節點
jQuery.prev(),返回上一個兄弟節點,不是全部的兄弟節點
jQuery.prevAll(),返回全部以前的兄弟節點
jQuery.next(),返回下一個兄弟節點,不是全部的兄弟節點
jQuery.nextAll(),返回全部以後的兄弟節點
jQuery.siblings(),返回兄弟姐妹節點,不分先後
jQuery.find(expr),跟jQuery.filter(expr)徹底不同。jQuery.filter()是從初始的jQuery對象集合中篩選出一部分,而jQuery.find()
的返回結果,不會有初始集合中的內容,好比$("p"),find("span"),是從<p>元素開始找<span>,等同於$("p span")