国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-21 00:50:32
字體:
供稿:網(wǎng)友
復(fù)制代碼 代碼如下:

//取得元素x坐標(biāo)
function pageX(elem) {
return elem.offsetParent?(elem.offsetLeft+pageX(elem.offsetParent)):elem.offsetLeft;
}
//取得元素y坐標(biāo)
function pageY(elem) {
return elem.offsetParent?(elem.offsetTop+pageY(elem.offsetParent)):elem.offsetTop;
}

貌似這位大神在出這本書時比較趕,有許多紕漏,最后大神也發(fā)覺這兩個函數(shù)有問題,并沒有把它們運(yùn)用到JQuery中。由于是用累加的方式去計算,只要一個元素出現(xiàn)問題,就有可能層層被大,因此我在精確獲取樣式屬性時就摒棄這種方法。主要誤算參照大神的結(jié)論
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返回的是一個集合,分別為元素在瀏覽器可視區(qū)的四個角的坐標(biāo)。

不過它在IE的標(biāo)準(zhǔn)模式存在一個奇怪的問題,html元素是有border的,默認(rèn)是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中進(jìn)行):

1、標(biāo)準(zhǔn)模式,沒有重設(shè)html的border


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

2、標(biāo)準(zhǔn)模式,重設(shè)html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

3、怪癖模式,沒有重設(shè)html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

4、怪癖模式,重設(shè)html的border

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

John Resig給出的方案就是用clientTop,clientLeft作減值。以下函數(shù)就是從JQuery中摳出來,就后就用它獲取頁面元素的坐標(biāo),比offset大法安全多了。
復(fù)制代碼 代碼如下:

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相當(dāng)于window.self.pageYOffset,是火狐的一個屬性,相當(dāng)于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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 连城县| 马鞍山市| 保康县| 临洮县| 汕尾市| 沈阳市| 邓州市| 巴东县| 鹰潭市| 揭东县| 隆回县| 二连浩特市| 普兰店市| 陆河县| 马关县| 广州市| 蒙城县| 云龙县| 汝南县| 息烽县| 徐水县| 化德县| 延庆县| 城市| 芮城县| 济南市| 福泉市| 航空| 利津县| 即墨市| 天津市| 黔江区| 长汀县| 白城市| 聂荣县| 张北县| 彩票| 洪雅县| 商河县| 宝清县| 河西区|