Jquery的parent和closet方法

jQuery 遍歷 - closest() 方法

<!DOCTYPE html>
<html>
 <head> 
  <script type="text/javascript" src="/jquery/jquery.js"></script> 
  <style>
  li { margin: 3px; padding: 3px; background: #EEEEEE; }
  li.hilight { background: yellow; }
</style> 
 </head> 
 <body> 
  <ul> 
   <li><b>Click me!</b></li> 
   <li>You can also <b>Click me!</b></li> 
  </ul> 
  <script>
  $(document).bind("click", function( e ) {
    $(e.target).closest("li").toggleClass("hilight");
  });
</script>   
 </body>
</html>

定義和用法

closest() 方法獲得匹配選擇器的第一個祖先元素,從當前元素開始沿 DOM 樹向上。

語法

.closest(selector)
參數 描述
selector 字符串值,包含匹配元素的選擇器表達式。

詳細說明

如果給定表示 DOM 元素集合的 jQuery 對象,.closest() 方法允許我們檢索 DOM 樹中的這些元素以及它們的祖先元素,並用匹配元素構造新的 jQuery 對象。.parents().closest() 方法類似,它們都沿 DOM 樹向上遍歷。兩者之間的差異儘管微妙,卻很重要:

.closest() .parents()
從當前元素開始 從父元素開始
沿 DOM 樹向上遍歷,直到找到已應用選擇器的一個匹配爲止。 沿 DOM 樹向上遍歷,直到文檔的根元素爲止,將每個祖先元素添加到一個臨時的集合;如果應用了選擇器,則會基於該選擇器對這個集合進行篩選。
返回包含零個或一個元素的 jQuery 對象 返回包含零個、一個或多個元素的 jQuery 對象

請看下面的 HTML 片段:

<ul id="one" class="level-1">
  <li class="item-i">I</li>
  <li id="ii" class="item-ii">II
  <ul class="level-2">
    <li class="item-a">A</li>
    <li class="item-b">B
      <ul class="level-3">
        <li class="item-1">1</li>
        <li class="item-2">2</li>
        <li class="item-3">3</li>
      </ul>
    </li>
    <li class="item-c">C</li>
  </ul>
  </li>
  <li class="item-iii">III</li>
</ul>

例子 1

假設我們執行一個從項目 A 開始的對 <ul> 元素的搜索:

<!DOCTYPE html>
<html>
 <head> 
  <script type="text/javascript" src="/jquery/jquery.js"></script> 
 </head> 
 <body> 
  <ul id="one" class="level-1"> 
   <li class="item-i">I</li> 
   <li id="ii" class="item-ii">II 
    <ul class="level-2"> 
     <li class="item-a">A</li> 
     <li class="item-b">B 
      <ul class="level-3"> 
       <li class="item-1">1</li> 
       <li class="item-2">2</li> 
       <li class="item-3">3</li> 
      </ul> </li> 
     <li class="item-c">C</li> 
    </ul> </li> 
   <li class="item-iii">III</li> 
  </ul> 
  <script>
$('li.item-a').closest('ul').css('background-color', 'red');
</script>  
 </body>
</html>

這會改變 level-2 <ul> 的顏色,這是因爲當向上遍歷 DOM 樹時會第一個遇到該元素。
在這裏插入圖片描述
例子 2
假設我們搜索的是 <li> 元素:

<!DOCTYPE html>
<html>
 <head> 
  <script type="text/javascript" src="/jquery/jquery.js"></script> 
 </head> 
 <body> 
  <ul id="one" class="level-1"> 
   <li class="item-i">I</li> 
   <li id="ii" class="item-ii">II 
    <ul class="level-2"> 
     <li class="item-a">A</li> 
     <li class="item-b">B 
      <ul class="level-3"> 
       <li class="item-1">1</li> 
       <li class="item-2">2</li> 
       <li class="item-3">3</li> 
      </ul> </li> 
     <li class="item-c">C</li> 
    </ul> </li> 
   <li class="item-iii">III</li> 
  </ul> 
  <script>
$('li.item-a').closest('li').css('background-color', 'red');
</script>  
 </body>
</html>

這會改變列表項目 A 的顏色。在向上遍歷 DOM 樹之前,.closest() 方法會從 li 元素本身開始搜索,直到選擇器匹配項目 A 爲止。

在這裏插入圖片描述

例子 3

我們可以傳遞 DOM 元素作爲 context,在其中搜索最接近的元素。

<!DOCTYPE html>
<html>
 <head> 
  <script type="text/javascript" src="/jquery/jquery.js"></script> 
 </head> 
 <body> 
  <ul id="one" class="level-1"> 
   <li class="item-i">I</li> 
   <li id="ii" class="item-ii">II 
    <ul class="level-2"> 
     <li class="item-a">A</li> 
     <li class="item-b">B 
      <ul class="level-3"> 
       <li class="item-1">1</li> 
       <li class="item-2">2</li> 
       <li class="item-3">3</li> 
      </ul> </li> 
     <li class="item-c">C</li> 
    </ul> </li> 
   <li class="item-iii">III</li> 
  </ul> 
  <script>
var listItemII = document.getElementById('ii');
$('li.item-a').closest('ul', listItemII).css('background-color', 'red');
$('li.item-a').closest('#one', listItemII).css('background-color', 'green');
</script>   
 </body>
</html>

以上代碼會改變 level-2 <ul> 的顏色,因爲它既是列表項 A 的第一個 <ul> 祖先,同時也是列表項 II 的後代。它不會改變 level-1

    的顏色,因爲它不是 list item II 的後代。
    在這裏插入圖片描述


jQuery 遍歷 - 祖先

祖先是父、祖父或曾祖父等等。

通過 jQuery,您能夠向上遍歷 DOM 樹,以查找元素的祖先。

向上遍歷 DOM 樹

這些 jQuery 方法很有用,它們用於向上遍歷 DOM 樹:

  • parent()
  • parents()
  • parentsUntil()

jQuery parent() 方法

parent() 方法返回被選元素的直接父元素。

該方法只會向上一級對 DOM 樹進行遍歷。

下面的例子返回每個 <span> 元素的的直接父元素:

實例

<!DOCTYPE html>
<html>
<head>
<style>
.ancestors *
{ 
display: block;
border: 2px solid lightgrey;
color: lightgrey;
padding: 5px;
margin: 15px;
}
</style>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parent().css({"color":"red","border":"2px solid red"});
});
</script>
</head>
<body>

<div class="ancestors">
  <div style="width:500px;">div (曾祖父)
    <ul>ul (祖父)  
      <li>li (直接父)
        <span>span</span>
      </li>
    </ul>   
  </div>

  <div style="width:500px;">div (祖父)   
    <p>p (直接父)
        <span>span</span>
      </p> 
  </div>
</div>

</body>
</html>

親自試一試

jQuery parents() 方法

parents() 方法返回被選元素的所有祖先元素,它一路向上直到文檔的根元素 (<html>)。

下面的例子返回所有 <span> 元素的所有祖先:
實例

<!DOCTYPE html>
<html>
<head>
<style>
.ancestors *
{ 
display: block;
border: 2px solid lightgrey;
color: lightgrey;
padding: 5px;
margin: 15px;
}
</style>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parents().css({"color":"red","border":"2px solid red"});
});
</script>
</head>

<body class="ancestors">body (曾曾祖父)
  <div style="width:500px;">div (曾祖父)
    <ul>ul (祖父)  
      <li>li (直接父)
        <span>span</span>
      </li>
    </ul>   
  </div>
</body>

<!-- 最外圍的紅色邊框,在 body 元素之前,是 html 元素(也是祖先)。 -->
</html>

在這裏插入圖片描述
您也可以使用可選參數來過濾對祖先元素的搜索。

下面的例子返回所有 <span> 元素的所有祖先,並且它是 <ul> 元素:
實例

<!DOCTYPE html>
<html>
<head>
<style>
.ancestors *
{ 
display: block;
border: 2px solid lightgrey;
color: lightgrey;
padding: 5px;
margin: 15px;
}
</style>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parents("ul").css({"color":"red","border":"2px solid red"});
});
</script>
</head>

<body class="ancestors">body (曾曾祖父)
  <div style="width:500px;">div (曾祖父)
    <ul>ul (祖父)  
      <li>li (直接父)
        <span>span</span>
      </li>
    </ul>   
  </div>
</body>

</html>

在這裏插入圖片描述

jQuery parentsUntil() 方法

parentsUntil() 方法返回介於兩個給定元素之間的所有祖先元素。

下面的例子返回介於 <span><div> 元素之間的所有祖先元素:

實例

<!DOCTYPE html>
<html>
<head>
<style>
.ancestors *
{ 
display: block;
border: 2px solid lightgrey;
color: lightgrey;
padding: 5px;
margin: 15px;
}
</style>
<script src="/jquery/jquery-1.11.1.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parentsUntil("div").css({"color":"red","border":"2px solid red"});
});
</script>
</head>

<body class="ancestors"> body (曾曾祖父)
  <div style="width:500px;">div (曾祖父)
    <ul>ul (祖父)  
      <li>li (直接父)
        <span>span</span>
      </li>
    </ul>   
  </div>
</body>

</html>

在這裏插入圖片描述


jquery DOM 父節點、祖先節點、子節點、子孫節點

一、獲取父節點、祖先節點:

  1. parents([selector])
    本方法用於選擇給定 jQuery 對象中包含的 DOM 元素或者 DOM 元素集的祖先節點,並將這些節點包裝成 jQuery 對象返回,返回的節點集是以從裏到外的順序排序的。同時,本方法還接受一個字符串選擇器,用於從返回的節點集中篩選符合選擇器的子元素集。

  2. parent([selector])
    本方法用於選擇給定 jQuery 對象中包含的 DOM 元素或者 DOM 元素集的父節點。它和 parents() 不同的是,它只向上搜索一層,而 parents() 會搜索整個 DOM 樹。本方法也可以接受一個字符串選擇器,用於篩選返回的元素。
    有人可能會問:一個 DOM 元素的父元素不是隻有一個麼,爲什麼還要一個 selector 選擇器進行篩選呢?其實一個 jQuery 對象可能包含有很多個 DOM 元素,例如$('a').parent() 就是選擇所有 <a> 標籤的父元素,這樣返回的就是一個元素集,所以可以進行篩選。

  3. closest(selector)
    本方法用於向上遍歷 jQuery 對象中包含的 DOM 元素或者 DOM 元素集的祖先節點,直到找到符合 selector 選擇器的節點爲止。

二、獲取子節點、子孫節點:

  1. chidren([selector])
    僅僅獲取的是下級節點,不包括孫子節點,可用選擇器選取。

  2. find([selector])
    搜索所有段落中的後代,可用選擇器獲取。


jquery獲取父元素及祖先元素

parent是找當前元素的第一個父節點,parents是找當前元素的所有父節點

先說一下parent和parents的區別

從字面上不難看出

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

parents則是取得一個包含着所有匹配元素的祖先元素的元素集合(不包含根元素)。可以通過一個可選的

表達式進行篩選。

可以看出parent的取值很明確,就是當前元素的父元素;parents則是當前元素的祖先元素。下面列出例子

說明:

<div id='div1'>

<div id='div2'><p></p></div>

<div id='div3' class='a'><p></p></div>

<div id='div4'><p></p></div>

</div>

$('p').parent()取到的是div2,div3,div4

$('p').parent('.a')取到的是div3

$('p').parent().parent()取到的是div1,這點比較奇特;不過Jquery對象本身的特點決定了這是可行的

$('p').parents()取到的是div1,div2,div3,div4

$('p').parents('.a')取到的是div3

parent(exp)用法:取得一個包含着所有匹配元素的唯一父元素的元素集合。

<script src="jquery-1.2.6.min.js" type="text/javascript"></script>

<script type="text/javascript"> 

    $(document).ready(function() {

        $("#btn1").click(function(){

        alert($(this).parent().next().html());

       });

    });
</script> 
發佈了323 篇原創文章 · 獲贊 549 · 訪問量 363萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章