.offsetParent()
.offsetParent() 返回: jQuery
描述: 返回最近的被定过位的祖先元素。(祖先元素指该元素的上级元素,即包着它的外层元素)
version added: 1.26.offsetParent()
提供一个代表一系列DOM元素的jQuery对象,
.offsetParent()
方法允许我们搜索DOM树里面该元素的祖先元素,然后构造一个jQuery对象,该jQuery对象包着最近的被定过位的祖先元素。
一个元素被定位的意思是该元素包含一个位置属性relative
, absolute
, 或者 fixed
.
这对于计算元素的位置很方便,计算位置可以帮助实现动画或者将元素放在页面上的特定位置。
例如如果一个页面包含一个嵌套的列表,里面有一个被定过位的元素:
<ul class="level-1"> <li class="item-i">I</li> <li class="item-ii" style="position: relative;">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>
如果我们从item A开始,我们可以通过下面的方法找到它的最近的被定过位的祖先元素:
$('li.item-a').offsetParent().css('background-color', 'red');
这将改变list item II的颜色,因为它被定位了。
例子:
寻找item "A."的offsetParent
<!DOCTYPE html>
<html>
<head>
<script src="http://code.jquery.com/jquery-latest.min.js"></script>
</head>
<body>
<ul class="level-1">
<li class="item-i">I</li>
<li class="item-ii" style="position: relative;">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>
<script>$('li.item-a').offsetParent().css('background-color', 'red');</script>
</body>
</html>