html ul li target,jQuery 遍历 - closest() 方法

定义和用法

closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。

语法

.closest(selector)

参数

描述

selector

字符串值,包含匹配元素的选择器表达式。

详细说明

如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索 DOM 树中的这些元素以及它们的祖先元素,并用匹配元素构造新的 jQuery 对象。.parents() 和 .closest() 方法类似,它们都沿 DOM 树向上遍历。两者之间的差异尽管微妙,却很重要:

.closest()

.parents()

从当前元素开始

从父元素开始

沿 DOM 树向上遍历,直到找到已应用选择器的一个匹配为止。

沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。

返回包含零个或一个元素的 jQuery 对象

返回包含零个、一个或多个元素的 jQuery 对象

请看下面的 HTML 片段:

  • I
  • II
    • A
    • B
      • 1
      • 2
      • 3
    • C
  • III

例子 1

假设我们执行一个从项目 A 开始的对

  • 元素的搜索:

$('li.item-a').closest('ul').css('background-color', 'red');

这会改变 level-2

  • 的颜色,这是因为当向上遍历 DOM 树时会第一个遇到该元素。

例子 2

假设我们搜索的是

元素:

$('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

  • 的颜色,因为它既是列表项 A 的第一个
    • 祖先,同时也是列表项 II 的后代。它不会改变 level-1
      • 的颜色,因为它不是 list item II 的后代。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值