• 技术文章 >web前端 >js教程

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

    2016-05-16 17:35:10原创873
    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!






    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
  • 相关文章推荐

    • 一文详解Angular父子组件间传数据的方法• 浅析nodejs中怎么使用JWT?• 一文详解Nodejs怎么卸载(步骤分享)• 一文聊聊Angular中的管道(PIPE)• 10 个编写更简洁React代码的实用小技巧
    1/1

    PHP中文网