jQuery 遍历 - closest() 方法
来源:互联网 发布:淘宝卖家货到付款骗局 编辑:程序博客网 时间:2024/06/08 07:21
实例
本例演示如何通过 closest() 完成事件委托。当被最接近的列表元素或其子后代元素被点击时,会切换黄色背景:
$( document ).bind("click", function( e ) { $( e.target ).closest("li")
.toggleClass("hilight"); });
亲自试一试
定义和用法
closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。
语法
.closest(selector)
详细说明
如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索 DOM 树中的这些元素以及它们的祖先元素,并用匹配元素构造新的 jQuery 对象。.parents() 和 .closest() 方法类似,它们都沿 DOM 树向上遍历。两者之间的差异尽管微妙,却很重要:
请看下面的 HTML 片段:
<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>
例子 1
假设我们执行一个从项目 A 开始的对 <ul> 元素的搜索:
$('li.item-a').closest('ul').css('background-color', 'red');
亲自试一试
这会改变 level-2 <ul> 的颜色,这是因为当向上遍历 DOM 树时会第一个遇到该元素。
例子 2
假设我们搜索的是 <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 的后代。
0 0
- jQuery 遍历 - closest() 方法
- jQuery遍历之closest()方法
- jQuery 遍历 - closest() 方法介绍及与parents()方法区别
- jQuery基础教程之DOM操作-遍历节点-closest()方法
- jquery closest方法
- jquery closest()方法
- jQuery closest() 方法
- jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析
- jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析
- jquery .parents(), .parent() 和 closest()方法
- jQuery 之 parent、parents 和 closest 方法
- jQuery(3-10)遍历,兄弟,子,closest(),节点
- closest jquery
- jquery的closest方法和parents方法的区别
- jQuery 遍历 - not() 方法
- jQuery 遍历 - each() 方法
- jQuery 遍历 - filter() 方法
- jQuery 遍历 - map() 方法
- 黑马程序员——学习日记
- Objective-C中,当self作为当前类时需要注意的细节
- C#中的垃圾回收机制
- HQL多对多条件查询
- Unbound classpath container: 'JRE System Library
- jQuery 遍历 - closest() 方法
- 100题解题报告
- UI delegate设计模式
- #1082 : 然而沼跃鱼早就看穿了一切
- contiki process 编程注意事项
- CMD命令清理电脑历史缓存和Cookies
- EVEN,ALIGN,ORG,dup指令的理解
- org.hibernate.AnnotationException: No identifier specified for entity
- 喜羊羊系列之【标准IO】