如: <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>
closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 返回包含零个或一个元素的 jQuery 对象。
$('li.item-a').closest('ul').css('background-color', 'red');中向上找到ul,那么类为level-2所包括的所有元素的颜色都没成红色。
$('li.item-a').closest('li').css('background-color', 'red');中到最近的li(也就是本身)会变成红色。
.parents()方法从父元素开始沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。返回包含零个、一个或多个元素的 jQuery 对象
$('li.item-a').parents('ul').css('background-color', 'red');中向上找到ul,那么类为level-2所包括的所有元素的颜色都没成红色。
$('li.item-a').closest('li').css('background-color', 'red');中会向上找,那么类为item-ii 中的所有原色的颜色都会变红。
<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>
closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 返回包含零个或一个元素的 jQuery 对象。
$('li.item-a').closest('ul').css('background-color', 'red');中向上找到ul,那么类为level-2所包括的所有元素的颜色都没成红色。
$('li.item-a').closest('li').css('background-color', 'red');中到最近的li(也就是本身)会变成红色。
.parents()方法从父元素开始沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。返回包含零个、一个或多个元素的 jQuery 对象
$('li.item-a').parents('ul').css('background-color', 'red');中向上找到ul,那么类为level-2所包括的所有元素的颜色都没成红色。
$('li.item-a').closest('li').css('background-color', 'red');中会向上找,那么类为item-ii 中的所有原色的颜色都会变红。