麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jQuery 遍歷- 關(guān)于closest() 的方法介紹以及與parents()的方法區(qū)別分析

2019-11-20 22:46:08
字體:
供稿:網(wǎng)友

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

語法:

.closest(selector)

參數(shù)selector為字符串值,包含匹配元素的選擇器表達(dá)式。

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

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

先看下面的示例:演示如何通過 closest() 完成事件委托。當(dāng)被最接近的列表元素或其子后代元素被點(diǎn)擊時(shí),會(huì)切換黃色背景
復(fù)制代碼 代碼如下:

<!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>

1、當(dāng)鼠標(biāo)點(diǎn)擊“You can also”時(shí),顏色出現(xiàn)變化。這是因?yàn)閏losest是從當(dāng)前元素開始向上遍歷的。而不同于parents()方法,是從當(dāng)前元素的父元素開始向上遍歷。

2、當(dāng)點(diǎn)擊Click me!時(shí),顏色也會(huì)變化。這同樣經(jīng)過上面步驟,從當(dāng)前元素向上匹配,只不過<b>不符合條件,再往上時(shí)遇見了<li>。
3、實(shí)例演示請(qǐng)?jiān)L問:http://www.w3school.com.cn/tiy/t.asp?f=jquery_traversing_closest

例2:

復(fù)制代碼 代碼如下:

<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>

復(fù)制代碼 代碼如下:

$('li.item-a').closest('ul').css('background-color', 'red');

結(jié)果:

這會(huì)改變 level-2 <ul> 的顏色,這是因?yàn)楫?dāng)向上遍歷 DOM 樹時(shí)會(huì)第一個(gè)遇到該元素。

如下圖所示:

假設(shè)我們搜索的是 <li> 元素

$('li.item-a').closest('li').css('background-color', 'red');

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

例子 3

我們可以傳遞 DOM 元素作為 context(即限定搜索的最大范圍),在其中搜索最接近的元素。

復(fù)制代碼 代碼如下:

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');

以上代碼會(huì)改變 level-2 <ul> 的顏色,因?yàn)樗仁橇斜眄?xiàng) A 的第一個(gè) <ul> 祖先,同時(shí)也是列表項(xiàng) II 的后代。

它不會(huì)改變 level-1 <ul> 的顏色,因?yàn)樗皇?list item II 的后代。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 少妇一级淫片高潮流水电影 | 国产精品视频yy9299一区 | 日本高清黄色片 | 一级免费黄色免费片 | 斗破苍穹在线免费 | 在线看一区二区三区 | 天使萌一区二区三区免费观看 | 天天骑夜夜操 | 精精国产xxxx视频在线播放7 | 日本特级a一片免费观看 | 日本爽快片100色毛片视频 | 国产亚洲欧美日韩高清 | 成人免费视频视频在线观看 免费 | 91亚洲免费视频 | 日本高清在线免费 | 日本高清黄色片 | 欧美日韩高清一区 | 精品一区二区免费 | 欧美日韩成人一区二区 | 午夜视频在线免费播放 | 黄污视频在线看 | 精品国产一区二区三区天美传媒 | 成人做爽爽爽爽免费国产软件 | 日韩在线毛片 | 国产一区精品视频 | 国产高清成人久久 | 精选久久 | av电影在线观看免费 | 午夜久久久久 | xxxxxx免费 | 亚洲成人免费网站 | 欧美日韩亚洲成人 | 日日鲁一鲁视频 | 女教师~淫辱の动漫在线 | 欧美成人二区 | 国产一级毛片国产 | 蜜桃视频日韩 | 美女很黄很黄免费的 | 久久久久免费精品 | 精品一区二区三区免费看 | 久久密|