jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析 - Web前端
作者:98wpeu发布时间:2026-06-15分类:网页前端技术浏览:6
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 的后代。
- 上一篇:JQuery中的$.getJSON 使用说明 - Web前端
- 下一篇:已经是最后一篇了
相关推荐
- 基于jquery的3d效果实现代码 - Web前端
- JQuery中的$.getJSON 使用说明 - Web前端
- 从零开始学习jQuery (八) 插播:jQuery实施方案 - Web前端
- 从零开始学习jQuery (七) jQuery动画实现 让页面动起来 - Web前端
- jquery实现手机发送验证码的倒计时代码 - Web前端
- JQuery 应用 JQuery.groupTable.js - Web前端
- JQuery动态给table添加、删除行 改进版 - Web前端
- 神奇的7个jQuery 3D插件整理 - Web前端
- jquery EasyUI的formatter格式化函数代码 - Web前端
- jquery $.ajax()取xml数据的小问题解决方法 - Web前端
- 网页前端技术排行
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


