jQuery - 遍历(一)之 祖先

jQuery 遍历,用于根据所要查找的元素相对于其他元素的关系来查找到该元素。

jQuery 提供了一系列的方法来向上遍历 DOM 树,以便查找到所选元素的祖先元素(父元素、祖父元素等)。

parent()

方法 描述
parent() 返回所选元素的直接父元素,只会向上一级对 DOM 树进行遍历。

代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>遍历01_祖先01_parent()</title>
    <script src="js/jquery-1.10.2.min.js"></script>
    <style>
        * {
            margin: auto;
            padding: 5px;
            border: 5px solid lightgray;
            color: darkgray;
        }

        #div1 {
            width: 400px;
            height: 400px;
        }

        #div11 {
            width: 300px;
            height: 300px;
        }

        #p1 {
            width: 200px;
            height: 200px;
        }

        #s1 {
            display: block;
            width: 100px;
            height: 100px;
        }
    </style>
</head>
<body>body(曾曾祖父元素)
<div id="div1">div(曾祖父元素)
    <div id="div11">div(祖父元素)
        <p id="p1">p(父元素)
            <span id="s1">span</span>
        </p>
    </div>
</div>
<script>
    $(function () {
        $("#s1").parent().css("border", "5px solid red");
    });
</script>
</body>
</html>

效果演示:

parent().png

parents(selector)

参数 类型 描述
selector String 可选。参数为空则返回所选元素的所有祖先元素,一路向上直到文档的根元素 (<html>);非空则返回所选元素的所有祖先元素中与选择器匹配的元素。

代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>遍历01_祖先02_parents()</title>
    <script src="js/jquery-1.10.2.min.js"></script>
    <style>
        * {
            margin: auto;
            padding: 5px;
            border: 5px solid lightgray;
            color: darkgray;
        }

        #div1 {
            width: 400px;
            height: 400px;
        }

        #div11 {
            width: 300px;
            height: 300px;
        }

        #p1 {
            width: 200px;
            height: 200px;
        }

        #s1 {
            display: block;
            width: 100px;
            height: 100px;
        }
    </style>
</head>
<body>body(曾曾祖父元素)
<div id="div1">div(曾祖父元素)
    <div id="div11">div(祖父元素)
        <p id="p1">p(父元素)
            <span id="s1">span</span>
        </p>
    </div>
</div>
<script>
    $(function () {
        $("#s1").parents().css("border", "5px solid red");
    });
</script>
</body>
</html>

效果演示:

parents(selector).png

closest(selector)

参数 类型 描述
selector String 必选。返回所选元素第一个匹配的祖先元素。

代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>遍历01_祖先03_closest()</title>
    <script src="js/jquery-1.10.2.min.js"></script>
    <style>
        * {
            margin: auto;
            padding: 5px;
            border: 5px solid lightgray;
            color: darkgray;
        }

        #div11 {
            width: 400px;
            height: 400px;
        }

        #div12 {
            width: 300px;
            height: 300px;
        }

        #p1 {
            width: 200px;
            height: 200px;
        }

        #s1 {
            display: block;
            width: 100px;
            height: 100px;
        }
    </style>
</head>
<body>body(曾曾祖父元素)
<div class="div1" id="div11">div(曾祖父元素)
    <div class="div1" id="div12">div(祖父元素)
        <p id="p1">p(父元素)
            <span id="s1">span</span>
        </p>
    </div>
</div>
<script>
    $(function () {
        $("#s1").closest(".div1").css("border", "5px solid red");
    });
</script>
</body>
</html>

效果演示:

closest(selector).png

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 通过jQuery,您可以选取(查询,query)HTML元素,并对它们执行“操作”(actions)。 jQuer...
    枇杷树8824阅读 670评论 0 3
  • DOM创建节点及节点属性 通过JavaScript可以很方便的获取DOM节点,从而进行一系列的DOM操作。但实际上...
    阿r阿r阅读 1,043评论 0 9
  • (续jQuery基础(1)) 第5章 DOM节点的复制与替换 (1)DOM拷贝clone() 克隆节点是DOM的常...
    凛0_0阅读 1,364评论 0 8
  • 第1章 简介 第2章 DOM节点的创建 2-1 DOM创建节点及节点属性 通过JavaScript可以很方便的获...
    mo默22阅读 838评论 0 8
  • 1:jQuery节点创建与属性的处理 创建元素节点:可以有几种方式,后面会慢慢接触。常见的就是直接把这个节点的结构...
    码农小杨阅读 625评论 0 1