<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-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>
$('li.item-a').closest('ul').css('background-color',
'red');
这会改变
level-2 <ul> 的颜色,这是因为当向上遍历 DOM 树时会第一个遇到该元素。
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');
我们可以传递
DOM 元素作为 context(即限定搜索的最大范围),在其中搜索最接近的元素。
以上代码会改变
level-2 <ul> 的颜色,因为它既是列表项 A 的第一个 <ul> 祖先,同时也是列表项 II 的后代。
listItemII
:
在这个规定的元素的后代中查找最近的满足选择器的父级元素,但不包括listItemII
自己
本文介绍了如何使用jQuery的closest()方法来查找DOM树中指定元素的最近祖先,并通过限定搜索范围来精确控制颜色变化的应用。同时展示了如何指定不同的上下文进行更细粒度的选择。
1359

被折叠的 条评论
为什么被折叠?



