一、獲取子節點 比如是一個 id 為 test 的 div元素,我們這樣選中,$('#test'),我們要查找這個div下的一個class為demo的span元素,有一下幾種方法
1、使用篩選條件
$('#test span.demo')
2、使用find()函數
$('#test').find('span.demo')
3、使用children()函數
$('#test').children('span.demo')
二、獲取父節點 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.$('#item1').parent().parent('.parent1');
2.$('li:parent');
3.$('#items').parents('.parent1');
4.$('#items1').closest('.parent1');
closest會首先檢查當前元素是否匹配,如果匹配則直接返回元素本身。如果不匹配則向上查找父元素,一層一層往上,直到找到匹配選擇器的元素。如果什麼都沒找到則返回一個空的jQuery對象。
closest和parents的主要區別是:1,前者從當前元素開始匹配尋找,後者從父元素開始匹配尋找;2,前者逐級向上查找,直到發現匹配的元素後 就停止了,後者一直向上查找直到根元素,然後把這些元素放進一個臨時集合中,再用給定的選擇器表達式去過濾;3,前者返回0或1個元素,後者可能包含0 個,1個,或者多個元素。closest對於處理事件委派非常有用。