成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

彈性布局元素瀏覽器

2011-03-04 14:58:40

jqueryJSON

2019-12-10 10:31:30

javascriptWeb前端開發

2021-07-29 10:00:24

Arrays工具類元素

2021-04-23 10:05:21

Docker運維命令

2009-09-25 15:34:42

Hibernate關聯

2010-10-15 13:37:08

獲取Mysql數據

2021-04-23 09:41:50

元素邊框CSS

2014-06-20 09:29:19

jQueryBootstrap

2013-12-02 14:29:27

jQuery元素屬性

2015-06-11 09:59:41

jquery翻譯jquery插件制作

2025-02-05 09:06:35

Spring項目目錄

2009-07-06 17:36:06

ResultSetJDBC Connec
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩精品专区在线影院重磅 | 国产视频久久 | 日韩欧美中文在线 | 69av片| 日韩二区 | 狠狠综合网 | 欧美久久国产精品 | 一级片免费视频 | 国产精品久久久久久久免费大片 | 久久久高清 | 老司机成人在线 | 亚洲精品在线免费 | 国产精品久久久久久久久久免费看 | 老头搡老女人毛片视频在线看 | 久久久青草婷婷精品综合日韩 | 毛片a级 | 免费毛片网 | 中文字幕高清 | 免费激情网站 | 久久之精品| 国产一级片在线观看视频 | 国产精品精品久久久 | 国产精品久久久久av | av久久 | 精品国产乱码久久久久久闺蜜 | 日韩一区二区三区在线 | 成人免费av | 国产乱码精品一区二区三区忘忧草 | 久久综合久久自在自线精品自 | 国产一区二区三区在线视频 | 国产成人jvid在线播放 | 日本欧美视频 | 亚洲精品一区中文字幕乱码 | 国产精品免费看 | 蜜桃精品视频在线 | 日韩伦理一区二区 | 国产日韩欧美 | 男女网站免费 | 99中文字幕| 欧美日韩综合一区 | 美女黄网站视频免费 |