js獲取元素在瀏覽器中的絕對位置
更新時間:2010年07月24日 00:56:53 作者:
其原理就是利用HTMLElement.offsetParent屬性,需要的朋友可以參考下。
JavaScript中提供獲取HTML元素位置的屬性:
HTMLElement.offsetLeft
HTMLElement.offsetHeight
但 是需要注意的是,這兩個屬性所儲存的數(shù)值并不是該元素相對整個瀏覽器畫布的絕對位置,而是相對于其父元素位置的相對位置,也就是說這兩個數(shù)值得到的是以其 父元素左上角為(0,0)點從而計算出的數(shù)值。那么如何得到一個HTML元素的絕對位置呢,可以用以下函數(shù):
//獲取元素的縱坐標
function getTop(e){
var offset=e.offsetTop;
if(e.offsetParent!=null) offset+=getTop(e.offsetParent);
return offset;
}
//獲取元素的橫坐標
function getLeft(e){
var offset=e.offsetLeft;
if(e.offsetParent!=null) offset+=getLeft(e.offsetParent);
return offset;
}
其原理就是利用HTMLElement.offsetParent屬性,如果當前元素的父元素不是空(null),則在原本的offsetTop基礎(chǔ)上加上當前的offsetTop,然后繼續(xù)獲取父元素的父元素的offsetTop,再將其加之,最終遞歸出該元素相對于整個瀏覽器畫布的縱坐標。橫坐標亦然。
HTMLElement.offsetLeft
HTMLElement.offsetHeight
但 是需要注意的是,這兩個屬性所儲存的數(shù)值并不是該元素相對整個瀏覽器畫布的絕對位置,而是相對于其父元素位置的相對位置,也就是說這兩個數(shù)值得到的是以其 父元素左上角為(0,0)點從而計算出的數(shù)值。那么如何得到一個HTML元素的絕對位置呢,可以用以下函數(shù):
復(fù)制代碼 代碼如下:
//獲取元素的縱坐標
function getTop(e){
var offset=e.offsetTop;
if(e.offsetParent!=null) offset+=getTop(e.offsetParent);
return offset;
}
//獲取元素的橫坐標
function getLeft(e){
var offset=e.offsetLeft;
if(e.offsetParent!=null) offset+=getLeft(e.offsetParent);
return offset;
}
其原理就是利用HTMLElement.offsetParent屬性,如果當前元素的父元素不是空(null),則在原本的offsetTop基礎(chǔ)上加上當前的offsetTop,然后繼續(xù)獲取父元素的父元素的offsetTop,再將其加之,最終遞歸出該元素相對于整個瀏覽器畫布的縱坐標。橫坐標亦然。
相關(guān)文章
JS封裝的三級聯(lián)動菜單(使用時只需要一行js代碼)
在實際的項目開發(fā)中,我們經(jīng)常需要三級聯(lián)動,比如省市區(qū)的選擇,商品的三級分類的選擇等等。這篇文章主要介紹了JS封裝的三級聯(lián)動菜單(使用時只需要一行js代碼)的相關(guān)資料,需要的朋友可以參考下2016-10-10
淺談nodeName,nodeValue,nodeType,typeof 的區(qū)別
本文主要簡單介紹了nodeName,nodeValue,nodeType,typeof 的區(qū)別,算是知識點的一個小總結(jié),希望對小伙伴們有所幫助2015-01-01
firefox下input type="file"的size是多大
firefox對type="file" 的input的width定義目前是不支持的,但是FF支持size屬性,可以給size設(shè)置一個值,來控制上傳框的大小2011-10-10

