源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-08-15 12:50 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析
closest() 方法获得匹配选择器的[b]第一个祖先元素[/b],[b]从当前元素开始[/b]沿 DOM 树向上。 [b]语法:[/b] .closest(selector) [b]参数selector为字符串值,包含匹配元素的选择器表达式。[/b] 如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索 DOM 树中的这些元素以及它们的祖先元素,并用匹配元素构造新的 jQuery 对象。.parents() 和 .closest() 方法类似,它们都沿 DOM 树向上遍历。两者之间的差异尽管微妙,却很重要:
.closest() .parents()
从当前元素开始 从父元素开始
沿 DOM 树向上遍历,直到找到已应用选择器的一个匹配为止。 沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。 
返回包含零个或一个元素的 jQuery 对象 返回包含零个、一个或多个元素的 jQuery 对象
先看下面的示例:演示如何通过 closest() 完成事件委托。当被最接近的列表元素或其子后代元素被点击时,会切换黄色背景
[u]复制代码[/u] 代码如下:
<!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:
[u]复制代码[/u] 代码如下:
<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>
[u]复制代码[/u] 代码如下:
$('li.item-a').closest('ul').css('background-color', 'red');
结果: 这会改变 level-2 <ul> 的颜色,这是因为当向上遍历 DOM 树时会第一个遇到该元素。 [b]如下图所示:[/b] [b][img]http://files.jb51.net/file_images/article/201304/2013042611243626.gif[/img] [/b] [b]假设我们搜索的是 <li> 元素[/b]
$('li.item-a').closest('li').css('background-color', 'red');
这会改变列表项目 A 的颜色。在向上遍历 DOM 树之前,.closest() 方法会从 li 元素本身开始搜索,直到选择器匹配项目 A 为止。 [b]例子 3[/b] 我们可以传递 DOM 元素作为 context(即限定搜索的最大范围),在其中搜索最接近的元素。
[u]复制代码[/u] 代码如下:
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 的后代。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部