jQuery parents() 方法
实例
返回 span 的所有祖先元素:
$(document).ready(function(){
$("span").parents().css({"color": "red", "border": "2px solid red"});
});
结果:
body (曾曾祖级)
div (曾祖级)
- ul (祖级)
- li (直接父级) span
完整代码如下:
<!DOCTYPE html>
<html>
<head>
<style>
.ancestors * {
display: block;
border: 2px solid lightgrey;
color: lightgrey;
padding: 5px;
margin: 15px;
}
</style>
<script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("span").parents().css({"color": "red", "border": "2px solid red"});
});
</script>
</head>
<body class="ancestors">body (曾曾祖级)
<div style="width:500px;">div (曾祖级)
<ul>ul (祖父级)
<li>li (直接父级)
<span>span</span>
</li>
</ul>
</div>
</body>
<!-- body 元素之前的外部红色边框是 html 元素(也是一个祖先) -->
</html>
定义与用法
parents()
方法返回所选元素的所有祖先元素。
祖先级是父级、祖父级、曾祖级元素等等。
DOM 树: 这个方法从父元素沿着 DOM 元素的祖先向上遍历,一直遍历到文档的根元素(<html>)。
注意: 如果
filter
参数为空,该函数将选择一组元素的所有祖先,从直接父元素一直到 <body> 和 <html>。因此,传递选择器表达式以缩小搜索结果的范围通常很有用。这个方法与 closest() 方法类似, 因为它们都遍历 DOM 树。区别如下:
parents()
- 从父元素开始
- 向上移动 DOM 树并返回与传递的表达式匹配的所有祖先元素
- 返回的 jQuery 对象包含 0 个或多个元素
closest()
- 从当前元素开始
- 向上遍历 DOM 树并返回与传递的表达式匹配的第一个祖先元素
- 返回的 jQuery 对象包含 0 个或 1 个元素
其他相关方法:
- parent() - 返回所选元素的直接父元素
- parentsUntil() - 返回两个给定参数之间的所有祖先元素
语法
$(selector).parents(filter)
参数 | 描述 |
---|---|
filter | 可选。指定用于缩小祖先搜索范围的选择器表达式 注意: 要返回多个祖先元素,请用逗号分隔每个表达式 |
更多实例
如何使用过滤器参数返回 ul 元素的所有 span 祖先元素