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 相关文章推荐
用javascript将数据库中的TEXT类型数据动态赋值到TEXTAREA中
Apr 20 Javascript
基于JQuery的密码强度验证代码
Mar 01 Javascript
Jquery事件的连接使用示例
Jun 18 Javascript
jquery仿搜索自动联想功能代码
May 23 Javascript
JS+CSS实现的蓝色table选项卡效果
Oct 08 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记8)
Dec 24 Javascript
深入理解(function(){... })();
Aug 16 Javascript
Jquery uploadify 多余的Get请求(404错误)的解决方法
Jan 26 Javascript
详解angular用$sce服务来过滤HTML标签
Apr 11 Javascript
使用webpack打包koa2 框架app
Feb 02 Javascript
Javascript数组方法reduce的妙用之处分享
Jun 10 Javascript
Vue项目中使用jsonp抓取跨域数据的方法
Nov 10 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判断浏览器的类型和语言的函数代码
2013/02/28 PHP
php 判断服务器操作系统的类型
2014/02/17 PHP
php 解决substr()截取中文字符乱码问题
2016/07/18 PHP
AJAX的使用方法详解
2017/04/29 PHP
JavaScript在浏览器标题栏上显示当前日期和时间的方法
2015/03/19 Javascript
js实现无缝循环滚动
2020/06/23 Javascript
JS实现title标题栏文字不间断滚动显示效果
2016/09/07 Javascript
Bootstrap源码解读导航(6)
2016/12/23 Javascript
bootstrap weebox 支持ajax的模态弹出框
2017/02/23 Javascript
Webpack执行命令参数详解
2017/06/17 Javascript
BootStrap 页签切换失效的解决方法
2017/08/17 Javascript
微信小程序列表渲染功能之列表下拉刷新及上拉加载的实现方法分析
2017/11/27 Javascript
jQuery实现文件编码成base64并通过AJAX上传的方法
2018/04/12 jQuery
vue 音乐App QQ音乐搜索列表最新接口跨域设置方法
2018/09/25 Javascript
小程序实现列表删除功能
2018/10/30 Javascript
webpack的pitching loader详解
2019/09/23 Javascript
详解小程序如何改变onLoad的执行时机
2019/11/01 Javascript
微信小程序在text文本实现多种字体样式
2019/11/08 Javascript
JavaScript Tab菜单实现过程解析
2020/05/13 Javascript
[02:37]2018DOTA2亚洲邀请赛赛前采访 VP.no[o]ne心中最强SOLO是谁
2018/04/04 DOTA
在Python中处理字符串之isdecimal()方法的使用
2015/05/20 Python
Python的dict字典结构操作方法学习笔记
2016/05/07 Python
Python使用回溯法子集树模板解决爬楼梯问题示例
2017/09/08 Python
Python配置虚拟环境图文步骤
2019/05/20 Python
python实现输入三角形边长自动作图求面积案例
2020/04/12 Python
解决python 虚拟环境删除包无法加载的问题
2020/07/13 Python
Python Selenium自动化获取页面信息的方法
2020/08/31 Python
简单聊聊H5的pushState与replaceState的用法
2018/04/03 HTML / CSS
澳大利亚相机之家:Camera House
2017/11/30 全球购物
欧姆龙医疗欧洲有限公司:Omron Healthcare Europe B.V
2020/06/13 全球购物
自我鉴定思想方面
2013/10/07 职场文书
2014自主招生自荐信策略
2014/01/27 职场文书
婚礼主持结束词
2014/03/13 职场文书
2014婚礼司仪主持词
2014/03/14 职场文书
2016年共产党员个人承诺书
2016/03/24 职场文书
创业分两种人:那么哪些适合创业?,哪些适合不适合创业呢?
2019/08/23 职场文书