jQuery提供的获取元素位置的接口方法

开发 前端
getBoundingClientRect最早是IE中实现的,后主流浏览器都实现了它。因此后面的else判断基本上用不上,jQuery可考虑去掉该段代码。

HTML元素的位置相关的css属性有top、left、bottom、right。要灵活使用这些属性,需要了解css的定位模型position:正常文档流相对定位绝对定位

了解了这些css知识才更清楚jQuery的position及offset的区别。

jQuery中提供了获取设置HTML元素位置的接口方法。如下

.offset()

.position()

.offsetParent()

.scrollTop()

.scrollLeft()

所有位置相关的代码在项目的offset.js中,总共250行代码。里面还有些未公开的方法,如

getOffset()

getWindow()

jQuery.offset.bodyOffset()

jQuery.offset.setOffset()

它们之间的关系如下

 从图中可以看到两个重要的函数.offset()和.position()都依赖于私有的getOffset()。

.position()还依赖于.offsetParent()。offsetParent通过while循环获取最近的定位父元素(position为非static值)。

getOffset()函数根据浏览器是否支持getBoundingClientRect得来。如果支持则使用getBoundingClientRect,否则使用while循环不断计算得出位置值。

getBoundingClientRect最早是IE中实现的,后主流浏览器都实现了它。因此后面的else判断基本上用不上,jQuery可考虑去掉该段代码。

需要注意下.offset()和.position()的区别

.offset()   相对于document(视口)计算的

.position() 相对于其最近的 定位父元素

此外,.offset()传入一个对象或函数时可以设置元素的位置(setter),而.position()则仅是获取位置(getter)。

.offset()作为getter时,获取dispaly:none的元素top,left都将是零。

.offset()作为setter时,如果没有元素的position(此时值为static),那么.offset()方法会将其设置为“relative”以相对于视口进行重新定位。如下

  1. 1 // set position first, in-case top/left are set even on static elem  
  2. 2 if ( position === "static" ) {  
  3. 3     elem.style.position = "relative";  
  4. 4 } 

相关:

http://www.w3.org/TR/cssom-view/#the-getclientrects

https://developer.mozilla.org/en/DOM/element.getBoundingClientRect

http://msdn.microsoft.com/en-us/library/ms536433%28VS.85%29.aspx

原文链接:http://www.cnblogs.com/snandy/archive/2012/04/23/2455787.html

责任编辑:张伟 来源: snandy的博客
相关推荐

2011-05-25 14:34:26

javascript

2010-09-28 13:40:52

DOM元素

2023-10-27 16:12:29

2021-09-13 07:53:30

安全

2021-08-26 10:07:25

数组前端元素

2020-11-30 15:33:33

访问数组

2015-03-25 11:42:52

Java删除特定元素

2024-06-06 08:46:26

弹性布局元素浏览器

2019-12-10 10:31:30

javascriptWeb前端开发

2011-03-04 14:58:40

jqueryJSON

2021-04-23 10:05:21

Docker运维命令

2010-10-15 13:37:08

获取Mysql数据

2009-09-25 15:34:42

Hibernate关联

2021-07-29 10:00:24

Arrays工具类元素

2013-12-02 14:29:27

jQuery元素属性

2021-04-23 09:41:50

元素边框CSS

2012-03-08 11:23:09

jQuery Mobi

2015-06-11 09:59:41

jquery翻译jquery插件制作

2014-06-20 09:29:19

jQueryBootstrap

2010-09-28 13:50:20

点赞
收藏

51CTO技术栈公众号