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


Posted in Javascript onApril 26, 2013

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 树时会第一个遇到该元素。

如下图所示:

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

假设我们搜索的是 <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 的后代。

Javascript 相关文章推荐
网页中实现浏览器的最大,最小化和关闭按钮
Mar 12 Javascript
jquery插件实现鼠标经过图片右侧显示大图的效果(类似淘宝)
Feb 04 Javascript
一个封装js代码-----展开收起效果示例
Jul 03 Javascript
使用JavaScript进行进制转换将字符串转换为十进制
Sep 21 Javascript
get(0).tagName获得作用标签示例代码
Oct 08 Javascript
JavaScript中Function详解
Feb 27 Javascript
jQuery实现Div拖动+键盘控制综合效果的方法
Mar 10 Javascript
通过扫描二维码打开app的实现代码
Nov 10 Javascript
Mint-UI时间组件起始时间问题及时间插件使用
Aug 20 Javascript
深入了解JavaScript 私有化
May 30 Javascript
H5实现手机拍照和选择上传功能
Dec 18 Javascript
微信小程序仿通讯录功能
Apr 09 Javascript
用JQuery 判断某个属性是否存在hasAttr的解决方法
Apr 26 #Javascript
关于jquery.validate1.9.0前台验证的使用介绍
Apr 26 #Javascript
jQuery.Validate验证库的使用介绍
Apr 26 #Javascript
基于jQuery.Validate验证库知识点的详解
Apr 26 #Javascript
关于jQuery新的事件绑定机制on()的使用技巧
Apr 26 #Javascript
利用js的Node遍历找到repeater的一个字段实例介绍
Apr 25 #Javascript
JS保留小数点(四舍五入、四舍六入)实现思路及实例
Apr 25 #Javascript
You might like
基于php-fpm的配置详解
2013/06/03 PHP
深入HTTP响应状态码速查表的详解
2013/06/07 PHP
PHP如何利用P3P实现跨域
2013/08/24 PHP
php使用function_exists判断函数可用的方法
2014/11/19 PHP
Yii2框架配置文件(Application属性)与调试技巧实例分析
2019/05/27 PHP
javaScript对象和属性的创建方法
2007/01/15 Javascript
实现js保留小数点后N位的代码
2014/11/13 Javascript
jQuery性能优化技巧分析
2015/02/20 Javascript
超赞的动手创建JavaScript框架的详细教程
2015/06/30 Javascript
javascript自定义滚动条实现代码
2020/04/20 Javascript
js获取当前日期时间及其它日期操作汇总
2016/03/08 Javascript
JS中的eval 为什么加括号
2016/04/13 Javascript
jQuery弹出下拉列表插件(实现kindeditor的@功能)
2016/08/16 Javascript
ionic由于使用了header和subheader导致被遮挡的问题的两种解决方法
2016/09/22 Javascript
原生js验证简洁注册登录页面
2016/12/17 Javascript
Node.js使用MySQL连接池的方法实例
2018/02/11 Javascript
Vue中控制v-for循环次数的实现方法
2018/09/26 Javascript
jQuery选择器之基本选择器用法实例分析
2019/02/19 jQuery
基于Python的关键字监控及告警
2017/07/06 Python
Python读取mat文件,并保存为pickle格式的方法
2018/10/23 Python
基于python生成器封装的协程类
2019/03/20 Python
详解python的argpare和click模块小结
2019/03/31 Python
Python统计文本词汇出现次数的实例代码
2020/02/27 Python
Elasticsearch py客户端库安装及使用方法解析
2020/09/14 Python
解析HTML5中的新功能本地存储localStorage
2016/03/01 HTML / CSS
Html5监听手机摇一摇事件的实现
2019/11/07 HTML / CSS
End Clothing美国站:英国男士潮牌商城
2018/04/20 全球购物
医务人员竞聘职务自我评价分享
2013/11/08 职场文书
有兼职工作经历的简历自我评价
2014/03/07 职场文书
电视购物广告词
2014/03/19 职场文书
村党支部换届选举方案
2014/05/02 职场文书
学习党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
2014年评职称工作总结
2014/11/20 职场文书
长城英文导游词
2015/01/30 职场文书
2015年全国“爱牙日”宣传活动总结
2015/03/23 职场文书
openstack中的rpc远程调用的方法
2021/07/09 Python