亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 22:46:08
字體:
來源:轉載
供稿:網友

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

語法:

.closest(selector)

參數selector為字符串值,包含匹配元素的選擇器表達式。

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

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

1、當鼠標點擊“You can also”時,顏色出現變化。這是因為closest是從當前元素開始向上遍歷的。而不同于parents()方法,是從當前元素的父元素開始向上遍歷。

2、當點擊Click me!時,顏色也會變化。這同樣經過上面步驟,從當前元素向上匹配,只不過<b>不符合條件,再往上時遇見了<li>。
3、實例演示請訪問:http://www.w3school.com.cn/tiy/t.asp?f=jquery_traversing_closest

例2:

復制代碼 代碼如下:

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

復制代碼 代碼如下:

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

結果:

這會改變 level-2 <ul> 的顏色,這是因為當向上遍歷 DOM 樹時會第一個遇到該元素。

如下圖所示:

假設我們搜索的是 <li> 元素

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

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

例子 3

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

復制代碼 代碼如下:

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

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

它不會改變 level-1 <ul> 的顏色,因為它不是 list item II 的后代。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产69精品久久久久9| 欧美特级www| 欧美日韩亚洲一区二区| 久久精品中文字幕免费mv| 亚洲精品一区二区三区婷婷月| 最近2019年日本中文免费字幕| 日本91av在线播放| 国产欧美亚洲精品| 69久久夜色精品国产69乱青草| 亚洲老板91色精品久久| 色噜噜亚洲精品中文字幕| 97超级碰碰人国产在线观看| 91探花福利精品国产自产在线| 日本精品一区二区三区在线| 国产免费一区二区三区在线能观看| 日韩综合视频在线观看| 91亚洲va在线va天堂va国| 久久久久久久久久久久av| 中文字幕在线日韩| 日韩美女激情视频| 激情久久av一区av二区av三区| 91欧美视频网站| 91精品91久久久久久| 欧美黄色片免费观看| 欧美激情在线有限公司| 91禁国产网站| 国产亚洲精品久久| 成人网中文字幕| 久久视频国产精品免费视频在线| 在线观看国产成人av片| 亚洲欧美三级在线| 欧美激情xxxx性bbbb| 亚洲福利在线视频| 亚洲精品动漫久久久久| 久久久久久97| 亚洲japanese制服美女| 久久久av亚洲男天堂| 亚洲国模精品私拍| 国产综合视频在线观看| 亚洲欧美制服另类日韩| 亚洲欧洲日产国码av系列天堂| 97超碰国产精品女人人人爽| 97色在线视频| 国产久一一精品| 97超级碰碰碰久久久| 成人免费高清完整版在线观看| 在线国产精品播放| 久久人人爽人人| 欧美激情视频一区| 国产91色在线|| 欧美日韩国内自拍| 中文字幕亚洲无线码在线一区| 91精品久久久久久久久中文字幕| 最近2019年手机中文字幕| 狠狠躁天天躁日日躁欧美| 97精品久久久中文字幕免费| 亚洲网站视频福利| 26uuu亚洲伊人春色| 日韩成人中文字幕| 久久久久久亚洲| 日韩精品中文字幕久久臀| 国产精品中文字幕在线| 国产精品va在线播放| 精品国产自在精品国产浪潮| 国产成人涩涩涩视频在线观看| 91精品久久久久久久久久| 亚洲欧美综合精品久久成人| 国产在线视频一区| 综合久久五月天| 国产精品久久久久久久久免费| 日本一本a高清免费不卡| 国产精品av在线播放| 精品国产区一区二区三区在线观看| 午夜精品理论片| 中文字幕九色91在线| 爽爽爽爽爽爽爽成人免费观看| 一区二区三区四区视频| 国产精品国内视频| 欧美日韩国产va另类| 国产精品69久久久久| 国产精品劲爆视频| 亚洲va久久久噜噜噜久久天堂| 国产欧美一区二区三区四区| 日韩精品极品在线观看播放免费视频| 欧美日韩不卡合集视频| 国产精品一区av| 夜夜嗨av色综合久久久综合网| 国产精品高潮呻吟久久av野狼| 国产suv精品一区二区| 69久久夜色精品国产69乱青草| 97成人精品视频在线观看| 97国产精品人人爽人人做| 久久久久久97| 国产精品啪视频| 国产精品视频专区| 国内精品小视频| 亚洲性av在线| 欧美乱大交做爰xxxⅹ性3| 久久香蕉精品香蕉| 在线视频中文亚洲| 国产日韩欧美中文在线播放| 精品国产乱码久久久久久婷婷| 成人免费在线视频网址| 成人国内精品久久久久一区| 97久久精品人人澡人人爽缅北| 亚洲欧美资源在线| 久热精品视频在线观看一区| 久久在线精品视频| 亚洲第一福利视频| 日韩高清电影免费观看完整版| 精品免费在线观看| 在线日韩日本国产亚洲| 日韩成人性视频| 97国产suv精品一区二区62| 国产精品尤物福利片在线观看| 怡红院精品视频| 色偷偷av一区二区三区乱| 亚洲天堂网在线观看| 欧美日韩国产中文精品字幕自在自线| 色综合久久中文字幕综合网小说| 亚洲性视频网址| 91美女片黄在线观| 国产欧美一区二区| 日韩黄色高清视频| 成人www视频在线观看| 久久97精品久久久久久久不卡| 日韩欧美国产成人| 国产91精品久| 精品福利樱桃av导航| 热久久视久久精品18亚洲精品| 亚洲日本中文字幕| 91色琪琪电影亚洲精品久久| 国产精欧美一区二区三区| 国产精品成人aaaaa网站| 国产在线观看91精品一区| 在线亚洲欧美视频| 国产成人avxxxxx在线看| 日日噜噜噜夜夜爽亚洲精品| 欧美精品在线网站| 国产在线精品一区免费香蕉| 亚洲成人a级网| 国产欧美一区二区三区视频| 国产欧美在线播放| 日韩在线视频中文字幕| 国产精品永久免费在线| 美女黄色丝袜一区| 91超碰中文字幕久久精品| 久久久久久亚洲精品不卡| 国产精品大陆在线观看| 米奇精品一区二区三区在线观看| 中文字幕日韩av电影| 亚洲男人天堂久| 亚洲激情国产精品| 精品久久久久人成| 日韩欧美成人免费视频| 欧美福利视频在线| 亚洲欧美日韩天堂| 亚洲精品一区久久久久久| 亚洲大胆人体av| 国产精品亚洲一区二区三区| 91在线中文字幕| 亚洲精品福利资源站| 久久久视频免费观看| 欧美性生活大片免费观看网址|