偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

開(kāi)發(fā) 前端
getBoundingClientRect最早是IE中實(shí)現(xiàn)的,后主流瀏覽器都實(shí)現(xiàn)了它。因此后面的else判斷基本上用不上,jQuery可考慮去掉該段代碼。

HTML元素的位置相關(guān)的css屬性有top、left、bottom、right。要靈活使用這些屬性,需要了解css的定位模型position:正常文檔流相對(duì)定位,絕對(duì)定位。

了解了這些css知識(shí)才更清楚jQuery的position及offset的區(qū)別。

jQuery中提供了獲取設(shè)置HTML元素位置的接口方法。如下

.offset()

.position()

.offsetParent()

.scrollTop()

.scrollLeft()

所有位置相關(guān)的代碼在項(xiàng)目的offset.js中,總共250行代碼。里面還有些未公開(kāi)的方法,如

getOffset()

getWindow()

jQuery.offset.bodyOffset()

jQuery.offset.setOffset()

它們之間的關(guān)系如下

 從圖中可以看到兩個(gè)重要的函數(shù).offset()和.position()都依賴于私有的getOffset()。

.position()還依賴于.offsetParent()。offsetParent通過(guò)while循環(huán)獲取最近的定位父元素(position為非static值)。

getOffset()函數(shù)根據(jù)瀏覽器是否支持getBoundingClientRect得來(lái)。如果支持則使用getBoundingClientRect,否則使用while循環(huán)不斷計(jì)算得出位置值。

getBoundingClientRect最早是IE中實(shí)現(xiàn)的,后主流瀏覽器都實(shí)現(xiàn)了它。因此后面的else判斷基本上用不上,jQuery可考慮去掉該段代碼。

需要注意下.offset()和.position()的區(qū)別

.offset()   相對(duì)于document(視口)計(jì)算的

.position() 相對(duì)于其最近的 定位父元素

此外,.offset()傳入一個(gè)對(duì)象或函數(shù)時(shí)可以設(shè)置元素的位置(setter),而.position()則僅是獲取位置(getter)。

.offset()作為getter時(shí),獲取dispaly:none的元素top,left都將是零。

.offset()作為setter時(shí),如果沒(méi)有元素的position(此時(shí)值為static),那么.offset()方法會(huì)將其設(shè)置為“relative”以相對(duì)于視口進(jìn)行重新定位。如下

  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 } 

相關(guān):

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

責(zé)任編輯:張偉 來(lái)源: snandy的博客
相關(guān)推薦

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

數(shù)組前端元素

2020-11-30 15:33:33

訪問(wèn)數(shù)組

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前端開(kāi)發(fā)

2021-07-29 10:00:24

Arrays工具類元素

2021-04-23 10:05:21

Docker運(yùn)維命令

2009-09-25 15:34:42

Hibernate關(guān)聯(lián)

2010-10-15 13:37:08

獲取Mysql數(shù)據(jù)

2021-04-23 09:41:50

元素邊框CSS

2013-12-02 14:29:27

jQuery元素屬性

2014-06-20 09:29:19

jQueryBootstrap

2015-06-11 09:59:41

jquery翻譯jquery插件制作

2012-03-08 11:23:09

jQuery Mobi

2025-02-05 09:06:35

Spring項(xiàng)目目錄
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)