天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript 精確獲取頁面元素的位置

復制代碼 代碼如下:
//取得元素x坐標
function pageX(elem) {
return elem.offsetParent?(elem.offsetLeft+pageX(elem.offsetParent)):elem.offsetLeft;
}
//取得元素y坐標
function pageY(elem) {
return elem.offsetParent?(elem.offsetTop+pageY(elem.offsetParent)):elem.offsetTop;
}

貌似這位大神在出這本書時比較趕,有許多紕漏,最后大神也發覺這兩個函數有問題,并沒有把它們運用到JQuery中。由于是用累加的方式去計算,只要一個元素出現問題,就有可能層層被大,因此我在精確獲取樣式屬性時就摒棄這種方法。主要誤算參照大神的結論:
Handling table border offsets.
Fixed positioned elements.
Scroll offsets within another element.
Borders of overflowed parent elements.
Miscalculation of absolutely positioned elements.

隨著新銳瀏覽器都支持IE的getBoundingClientRect方法,我們得以用更簡單更快捷更安全的方法來定位頁面元素。getBoundingClientRect返回的是一個集合,分別為元素在瀏覽器可視區的四個角的坐標。

不過它在IE的標準模式存在一個奇怪的問題,html元素是有border的,默認是2px,并且是不可修改的;怪癖模式是沒有的。詳見http://msdn.microsoft.com/en-us/library/ms536433(VS.85).ASPx

This method retrieves an object that exposes the left, top, right, and bottom coordinates of the union of rectangles relative to the client's upper-left corner. In Microsoft InterNET Explorer 5, the window's upper-left is at 2,2 (pixels) with respect to the true client.

我們做一些測試(請分別在IE6與IE8中進行):

1、標準模式,沒有重設html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
2、標準模式,重設html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
3、怪癖模式,沒有重設html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
4、怪癖模式,重設html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
John Resig給出的方案就是用clientTop,clientLeft作減值。以下函數就是從JQuery中摳出來,就后就用它獲取頁面元素的坐標,比offset大法安全多了。
復制代碼 代碼如下:
var getCoords = function(el){
var box = el.getBoundingClientRect(),
doc = el.ownerDocument,
body = doc.body,
html = doc.documentElement,
clientTop = html.clientTop || body.clientTop || 0,
clientLeft = html.clientLeft || body.clientLeft || 0,
top = box.top + (self.pageYOffset || html.scrollTop || body.scrollTop ) - clientTop,
left = box.left + (self.pageXOffset || html.scrollLeft || body.scrollLeft) - clientLeft
return { 'top': top, 'left': left };
};

其中self.pageYOffset相當于window.self.pageYOffset,是火狐的一個屬性,相當于document.body.scrollTop。以下是它的定義:
Definition: The pageYOffset property is used to determine the Y coordinate of the scroll position in some browsers. This is not a reserved word so you can declare your own variable or function called pageYOffset but if you do then you will not be able to find or alter the scroll position of a window in some browsers

JavaScript技術javascript 精確獲取頁面元素的位置,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: WWW久久只有这里有精品 | 午夜国产理论 | 亚洲精品入口一区二区乱麻豆精品 | 色综合伊人色综合网站 | 精品亚洲一区二区在线播放 | 久9青青cao精品视频在线 | 麻豆国产人妻精品无码AV | 快播h网站 | 久久re亚洲在线视频 | 哒哒哒影院在线观看免费高清 | 欧美xxxxxbb| 天堂精品国产自在自线 | 爱情岛论坛网亚洲品质 | 2022一本久道久久综合狂躁 | 国产精品人妻无码免费A片导航 | 亚洲成a人不卡在线观看 | 国产亚洲免费观看 | 国产精品久久久久久精品... | 亚洲偷偷自拍免费视频在线 | 啦啦啦影院视频在线看高清... | 97国产精品久久精品国产 | 嫩草影院在线观看精品 | 欧美日韩视频一区二区三区 | 国产啪精品视频网免费 | 女人高潮了拔出来了她什么感觉 | 夜里18款禁用的免费B站动漫 | 日韩毛片在线视频 | 国产午夜精品久久久久九九 | 成人在线免费看片 | 久操久操久操 | 亚洲另类中文字幕 | 午夜亚洲国产理论片二级港台二级 | 日日射日日操 | 男的插曲女的下面免费APP | 国产亚洲精品久久久久久鸭绿欲 | 男人私gay挠脚心vk视频 | 3a丝袜论坛| 伊在香蕉国产在线视频 | 国产自拍视频在线一区 | 国产精品久久久久AV麻豆 | 久久婷婷五月综合色情 |