• jQuery 遍历


     

    实例

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

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

    亲自试一试

    定义和用法

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

    语法

    .closest(selector)
    参数描述
    selector 字符串值,包含匹配元素的选择器表达式。

    详细说明

    如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索 DOM 树中的这些元素以及它们的祖先元素,并用匹配元素构造新的 jQuery 对象。.parents() 和 .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 开始的对 <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');
  • 相关阅读:
    01-JAVA语言基础(动手动脑)
    大道至简第一章JAVA伪代码形式读后感
    《美国教授写给被开除中国留学生的信》阅读笔记
    《大道至简》读后感
    使用java2Word生成Word文档打不开报错 存在非法字符xml
    继上篇博客对安卓爬虫以及TextView更新的问题解释
    安卓Jsoup爬虫
    AndroidStdio模拟器打不开报错 Guest isn't online after 7 seconds
    MapReduce
    水晶报表报错:log4net初始值问题
  • 原文地址:https://www.cnblogs.com/kunlunmountain/p/5710811.html
Copyright © 2020-2023  润新知