jQuery parents() 方法

实例

返回 span 的所有祖先元素:

  1. $(document).ready(function(){
  2. $("span").parents().css({"color": "red", "border": "2px solid red"});
  3. });

结果:

body (曾曾祖级)
div (曾祖级)
    ul (祖级)
  • li (直接父级) 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>

定义与用法

parents() 方法返回所选元素的所有祖先元素。

祖先级是父级、祖父级、曾祖级元素等等。

DOM 树: 这个方法从父元素沿着 DOM 元素的祖先向上遍历,一直遍历到文档的根元素(<html>)。

注意: 如果 filter 参数为空,该函数将选择一组元素的所有祖先,从直接父元素一直到 <body> 和 <html>。因此,传递选择器表达式以缩小搜索结果的范围通常很有用。

这个方法与 closest() 方法类似, 因为它们都遍历 DOM 树。区别如下:

parents()

  • 从父元素开始
  • 向上移动 DOM 树并返回与传递的表达式匹配的所有祖先元素
  • 返回的 jQuery 对象包含 0 个或多个元素

closest()

  • 从当前元素开始
  • 向上遍历 DOM 树并返回与传递的表达式匹配的第一个祖先元素
  • 返回的 jQuery 对象包含 0 个或 1 个元素

其他相关方法:

  • parent() - 返回所选元素的直接父元素
  • parentsUntil() - 返回两个给定参数之间的所有祖先元素

语法

  1. $(selector).parents(filter)
参数描述
filter可选。指定用于缩小祖先搜索范围的选择器表达式
注意: 要返回多个祖先元素,请用逗号分隔每个表达式

更多实例

如何使用过滤器参数返回 ul 元素的所有 span 祖先元素

如何使用 filter 参数返回 span 中 li 和 div 元素的所有祖先元素

通过标记名显示元素的祖先

分类导航