最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 21:09:08
文档

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

jQuery遍历-关于closest()的方法介绍以及与parents()的方法区别分析_jquery:closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 语法: .closest(selector) 参数selector为字符串值,包含匹配元素的选择器表达式。 如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索
推荐度:
导读jQuery遍历-关于closest()的方法介绍以及与parents()的方法区别分析_jquery:closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 语法: .closest(selector) 参数selector为字符串值,包含匹配元素的选择器表达式。 如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索


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

语法:

.closest(selector)

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

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

.closest() .parents()
从当前元素开始 从父元素开始
沿 DOM 树向上遍历,直到找到已应用选择器的一个匹配为止。 沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。
返回包含零个或一个元素的 jQuery 对象 返回包含零个、一个或多个元素的 jQuery 对象

先看下面的示例:演示如何通过 closest() 完成事件委托。当被最接近的列表元素或其子后代元素被点击时,会切换黄色背景
代码如下:








  • Click me!

  • You can also Click me!



  • $( document ).bind("click", function( e ) {
    $( e.target ).closest("li").toggleClass("hilight");
    });




    1、当鼠标点击“You can also”时,颜色出现变化。这是因为closest是从当前元素开始向上遍历的。而不同于parents()方法,是从当前元素的父元素开始向上遍历。

    2、当点击Click me!时,颜色也会变化。这同样经过上面步骤,从当前元素向上匹配,只不过不符合条件,再往上时遇见了


  • 3、实例演示请访问:http://www.w3school.com.cn/tiy/t.asp?f=jquery_traversing_closest

    例2:
    代码如下:

  • I

  • II

  • A

  • B

  • 1

  • 2

  • 3



  • C



  • III



  • 代码如下:
    $('li.item-a').closest('ul').css('background-color', 'red');

    结果:

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

    如下图所示:

    假设我们搜索的是

  • 元素

    $('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 的后代。

  • 文档

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

    jQuery遍历-关于closest()的方法介绍以及与parents()的方法区别分析_jquery:closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 语法: .closest(selector) 参数selector为字符串值,包含匹配元素的选择器表达式。 如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索
    推荐度:
    标签: 方法 jQuery parents()
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top