Javascript獲取頁(yè)面元素的絕對(duì)位置實(shí)現(xiàn)
一、概念
絕對(duì)位置:網(wǎng)頁(yè)元素的左上角相對(duì)于整張網(wǎng)頁(yè)左上角的坐標(biāo)
相對(duì)位置:相對(duì)于瀏覽器窗口左上角的坐標(biāo)
二、獲取方法
1、每個(gè)元素都有offsetTop和offsetLeft屬性,表示該元素的左上角與父容器(offsetParent對(duì)象)左上角的距離。
2、每個(gè)元素都有offsetParent屬性。offsetParent屬性返回一個(gè)對(duì)象的引用,這個(gè)對(duì)象是距離調(diào)用offsetParent的元素最近的(在包含層次中最靠近的),并且是已進(jìn)行過CSS定位的容器元素。 如果這個(gè)容器元素未進(jìn)行CSS定位, 則offsetParent屬性的取值為根元素(在標(biāo)準(zhǔn)兼容模式下為html元素;在怪異呈現(xiàn)模式下為body元素)的引用。
當(dāng)容器元素的style.display 被設(shè)置為 "none"時(shí)(譯
注:IE和Opera除外),offsetParent屬性 返回 null 。
所以,只需要循環(huán)取得頁(yè)面元素的offsetParent,并逐步累加offsetTop和offsetLeft,就可以得到該元素的絕對(duì)坐標(biāo)。
三、代碼
function getElementAbsPos(e)
{
var t = e.offsetTop;
var l = e.offsetLeft;
while(e = e.offsetParent)
{
t += e.offsetTop;
l += e.offsetLeft;
}
return {left:l,top:t};
}四、問題
由于在iframe中,offsetParent對(duì)象未必等于父容器(同樣的,還有表格),所以通過getElementAbsPos函數(shù)得到并不是頁(yè)面元素的絕對(duì)位置,如下圖所示:
下面給出一個(gè)在iframe中正確獲取頁(yè)面元素的絕對(duì)位置的代碼:
/**
* @param e 頁(yè)面元素
* @param arrParentid 頁(yè)面元素e所在的iframe的數(shù)組
* @param isID 參數(shù)arrParentid中是iframe的id還是object
*/
function getElementAbsPos(e,arrParentid,isID)
{
var t = e.offsetTop;
var l = e.offsetLeft;
while(e = e.offsetParent)
{
t += e.offsetTop;
l += e.offsetLeft;
}
if(arguments.length >= 2)
{
for(var i=0; i<arrParentid.length; i++)
{
e = (isID==true) ? top.document.getElementById(arrParentid[i]) : arrParentid[i];
t += e.offsetTop;
l += e.offsetLeft;
while(e = e.offsetParent)
{
t += e.offsetTop;
l += e.offsetLeft;
}
}
}
return {left:l,top:t};
}
以上就是Javascript獲取頁(yè)面元素的絕對(duì)位置實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于Javascript元素絕對(duì)位置的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JS實(shí)現(xiàn)的簡(jiǎn)單分頁(yè)功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)的簡(jiǎn)單分頁(yè)功能,涉及javascript事件響應(yīng)及頁(yè)面元素遍歷、動(dòng)態(tài)構(gòu)造等相關(guān)操作技巧,需要的朋友可以參考下2018-08-08
微信公眾號(hào)授權(quán)登錄的超詳細(xì)步驟
微信公眾號(hào)授權(quán)登錄的使用最為常見,當(dāng)然只是一些會(huì)只有登錄,所以選擇點(diǎn)擊授權(quán)登,下面這篇文章主要給大家介紹了微信公眾號(hào)授權(quán)登錄的超詳細(xì)步驟,需要的朋友可以參考下2022-12-12
Bootstrap和Java分頁(yè)實(shí)例第二篇
這篇文章主要為大家詳細(xì)介紹了Bootstrap和Java分頁(yè)實(shí)例第二篇,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
js實(shí)現(xiàn)點(diǎn)擊注冊(cè)按鈕開始讀秒倒計(jì)時(shí)的小例子
js實(shí)現(xiàn)點(diǎn)擊注冊(cè)按鈕開始讀秒倒計(jì)時(shí)的小例子,需要的朋友可以參考一下2013-05-05
js動(dòng)態(tài)實(shí)現(xiàn)表格添加和刪除操作
這篇文章主要為大家詳細(xì)介紹了js動(dòng)態(tài)實(shí)現(xiàn)表格添加和刪除操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
淺析JS給原始數(shù)據(jù)類型加屬性和方法為什么不報(bào)錯(cuò)
這篇文章主要想和大家一起探討一下JavaScript中給原始數(shù)據(jù)類型添加屬性和方法為什么不報(bào)錯(cuò),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下2023-11-11
微信小程序調(diào)用騰訊地圖API文檔JavaScript?SDK和WebService?API詳細(xì)解讀
本文介紹了如何使用騰訊位置服務(wù),包括申請(qǐng)開發(fā)者密鑰、獲取小程序APPID、下載地圖SDK、設(shè)置服務(wù)器域名白名單等步驟,詳細(xì)說明了如何在微信小程序中集成騰訊位置服務(wù),進(jìn)行地圖展示和周邊搜索等功能的實(shí)現(xiàn),同時(shí)提醒注意API的調(diào)用次數(shù)和權(quán)限限制,需要的朋友可以參考下2024-09-09
js實(shí)現(xiàn)精確到秒的日期選擇器完整實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)精確到秒的日期選擇器,以完整實(shí)例形式分析了JavaScript日期選擇器的實(shí)現(xiàn)步驟與相關(guān)技巧,涉及JavaScript針對(duì)時(shí)間與日期的相關(guān)運(yùn)算,需要的朋友可以參考下2016-04-04

