多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
# jQuery 遍历 - closest() 方法 ## 实例 本例演示如何通过 closest() 完成事件委托。当被最接近的列表元素或其子后代元素被点击时,会切换黄色背景: ``` $( document ).bind("click", function( e ) { $( e.target ).closest("li").toggleClass("hilight"); }); ``` ## 定义和用法 closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 ### 语法 ``` .closest(_selector_) ``` | 参数 | 描述 | | --- | --- | | _selector_ | 字符串值,包含匹配元素的选择器表达式。 | ### 详细说明 如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索 DOM 树中的这些元素以及它们的祖先元素,并用匹配元素构造新的 jQuery 对象。[.parents()](/jquery/traversing_parents.asp) 和 .closest() 方法类似,它们都沿 DOM 树向上遍历。两者之间的差异尽管微妙,却很重要: | .closest() | .parents() | | --- | --- | | 从当前元素开始 | 从父元素开始 | | 沿 DOM 树向上遍历,直到找到已应用选择器的一个匹配为止。 | 沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。 | | 返回包含零个或一个元素的 jQuery 对象 | 返回包含零个、一个或多个元素的 jQuery 对象 | 请看下面的 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 开始的对 &lt;ul&gt; 元素的搜索: ``` $('li.item-a').closest('ul').css('background-color', 'red'); ``` 这会改变 level-2 &lt;ul&gt; 的颜色,这是因为当向上遍历 DOM 树时会第一个遇到该元素。 ### 例子 2 假设我们搜索的是 &lt;li&gt; 元素: ``` $('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 &lt;ul&gt; 的颜色,因为它既是列表项 A 的第一个 &lt;ul&gt; 祖先,同时也是列表项 II 的后代。它不会改变 level-1 &lt;ul&gt; 的颜色,因为它不是 list item II 的后代。