jQuery 祖先元素

使用 jQuery,您可以遍历 DOM 树来查找元素的祖先。

祖先是父、祖父、曾祖父等等。


向上遍历 DOM 树

下面是 3 种用于遍历 DOM 树的有用 jQuery 方法:

  • parent()
  • parents()
  • parentsUntil()

jQuery parent() 方法

parent() 方法返回所选元素的直接父元素。

此方法只遍历 DOM 树上的一个级别。

下面的实例返回每个 <span> 元素的直接父元素:

实例
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. .ancestors * {
  6. display: block;
  7. border: 2px solid lightgrey;
  8. color: lightgrey;
  9. padding: 5px;
  10. margin: 15px;
  11. }
  12. </style>
  13. <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
  14. <script>
  15. $(document).ready(function(){
  16. $("span").parent().css({"color": "red", "border": "2px solid red"});
  17. });
  18. </script>
  19. </head>
  20. <body>
  21. <div class="ancestors">
  22. <div style="width:500px;">div (曾祖级)
  23. <ul>ul (祖父级)
  24. <li>li (直接父级)
  25. <span>span</span>
  26. </li>
  27. </ul>
  28. </div>
  29. <div style="width:500px;">div (祖父级)
  30. <p>p (直接父级)
  31. <span>span</span>
  32. </p>
  33. </div>
  34. </div>
  35. </body>
  36. </html>

jQuery parents() 方法

parents() 方法返回所选元素的所有祖先元素,一直到文档的根元素(<html>)。

下面的实例返回所有 <span> 元素的所有祖先:

实例
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. .ancestors * {
  6. display: block;
  7. border: 2px solid lightgrey;
  8. color: lightgrey;
  9. padding: 5px;
  10. margin: 15px;
  11. }
  12. </style>
  13. <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
  14. <script>
  15. $(document).ready(function(){
  16. $("span").parents().css({"color": "red", "border": "2px solid red"});
  17. });
  18. </script>
  19. </head>
  20. <body class="ancestors">body (祖先级)
  21. <div style="width:500px;">div (曾祖级)
  22. <ul>ul (祖父级)
  23. <li>li (直接父级)
  24. <span>span</span>
  25. </li>
  26. </ul>
  27. </div>
  28. </body>
  29. <!-- body 元素之前的外部红色边框是 html 元素(也是一个祖先级) -->
  30. </html>

还可以使用可选参数筛选祖先搜索。

下面的实例返回所有 <span> 元素的所有祖先,这些元素都是 <ul> 元素:

实例
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. .ancestors * {
  6. display: block;
  7. border: 2px solid lightgrey;
  8. color: lightgrey;
  9. padding: 5px;
  10. margin: 15px;
  11. }
  12. </style>
  13. <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
  14. <script>
  15. $(document).ready(function(){
  16. $("span").parents("ul").css({"color": "red", "border": "2px solid red"});
  17. });
  18. </script>
  19. </head>
  20. <body class="ancestors">body (祖先级)
  21. <div style="width:500px;">div (曾祖级)
  22. <ul>ul (祖父级)
  23. <li>li (直接父级)
  24. <span>span</span>
  25. </li>
  26. </ul>
  27. </div>
  28. </body>
  29. </html>

jQuery parentsUntil() 方法

parentsUntil() 方法返回两个给定参数之间的所有祖先元素。

下面的实例返回 <span><div> 元素之间的所有祖先元素:

实例
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. .ancestors * {
  6. display: block;
  7. border: 2px solid lightgrey;
  8. color: lightgrey;
  9. padding: 5px;
  10. margin: 15px;
  11. }
  12. </style>
  13. <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
  14. <script>
  15. $(document).ready(function(){
  16. $("span").parentsUntil("div").css({"color": "red", "border": "2px solid red"});
  17. });
  18. </script>
  19. </head>
  20. <body class="ancestors"> body (祖先级)
  21. <div style="width:500px;">div (曾祖级)
  22. <ul>ul (祖父级)
  23. <li>li (直接父级)
  24. <span>span</span>
  25. </li>
  26. </ul>
  27. </div>
  28. </body>
  29. </html>

jQuery 遍历参考

有关所有 jQuery 遍历方法的完整概述,请访问本站的 jQuery 遍历参考