加载中...

offsetParent()


概述    .offsetParent()

返回值:jQuery

描述:取得离指定元素最近的含有定位信息的祖先元素。含有定位信息的元素指的是,CSS 的 position 属性是 relative, absolute, 或 fixed 的元素。

  • V : 1.2.6.offsetParent()

    • 这个方法不接受任何参数。

如果提供一个代表一系列DOM元素的jQuery对象, .offsetParent()方法允许我们搜索DOM树里面该元素的祖先元素,然后构建一个新的jQuery对象,该jQuery对象包着最近的被定过位的祖先元素。 一个元素被定位的意思是该元素包含一个位置属性relative, absolute, 或者 fixed. 这对于计算元素的位置很方便,计算位置可以帮助实现动画或者将元素放在页面上的特定位置。

例如如果一个页面包含一个嵌套的列表,里面有一个被定过位的元素:

  1. <ul class="level-1">
  2. <li class="item-i">I</li>
  3. <li class="item-ii" style="position: relative;">II
  4. <ul class="level-2">
  5. <li class="item-a">A</li>
  6. <li class="item-b">B
  7. <ul class="level-3">
  8. <li class="item-1">1</li>
  9. <li class="item-2">2</li>
  10. <li class="item-3">3</li>
  11. </ul>
  12. </li>
  13. <li class="item-c">C</li>
  14. </ul>
  15. </li>
  16. <li class="item-iii">III</li>
  17. </ul>

如果我们从项目 A开始,我们可以通过下面的方法找到它的最近的被定过位的祖先元素:

  1. $('li.item-a').offsetParent().css('background-color', 'red');

这将改变列表项 II的颜色,因为它被定位了。

示例

寻找item "A"的offsetParent

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <script src="http://code.jquery.com/jquery-latest.js"></script>
  5. </head>
  6. <body>
  7. <ul class="level-1">
  8. <li class="item-i">I</li>
  9. <li class="item-ii" style="position: relative;">II
  10. <ul class="level-2">
  11. <li class="item-a">A</li>
  12. <li class="item-b">B
  13. <ul class="level-3">
  14. <li class="item-1">1</li>
  15. <li class="item-2">2</li>
  16. <li class="item-3">3</li>
  17. </ul>
  18. </li>
  19. <li class="item-c">C</li>
  20. </ul>
  21. </li>
  22. <li class="item-iii">III</li>
  23. </ul>
  24. <script>$('li.item-a').offsetParent().css('background-color', 'red');</script>
  25. </body>
  26. </html>

运行一下


还没有评论.