jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析

2020-05-23 06:03:52易采站长站整理

  <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 的后代。