首頁 >web前端 >js教程 >js取得控制項位置以及不同瀏覽器中的差別介紹_javascript技巧

js取得控制項位置以及不同瀏覽器中的差別介紹_javascript技巧

WBOY
WBOY原創
2016-05-16 17:26:201162瀏覽
複製程式碼 程式碼如下:

//取得座標位置
function getpos(e) { var t=e.offsetTop;
var l=e.offsetLeft;
var height=e.offsetHeight;
while(e=e.offsetParent) {
t =e.offsetTop;
l =e.offsetLeft;
}
}

假設obj 為某個HTML 控制項。
obj.offsetTop 指 obj 距離上方或上層控制的位置,整型,單位像素。
obj.offsetLeft 指 obj 距離左方或上層控制的位置,整型,單位像素。
obj.offsetWidth 指 obj 控制項本身的寬度,整數,單位像素。
obj.offsetHeight 指 obj 控制項本身的高度,整型,單位像素。

我們對前面提到的「上方或上層」與「左方或上層」控制項作個說明。

例如:

複製程式碼 程式碼如下:

程式碼如下:







「提交」按鈕的offsetTop 指「提交」按鈕距「tool」層上邊框的距離,因為距其上邊最近的是「tool」 層的上邊框。
「重設」按鈕的 offsetTop 指「重設」按鈕與「tool」層上邊框的距離,因為距其上邊最近的是 「tool」 層的上方邊框。

「提交」按鈕的 offsetLeft 指「提交」按鈕距「tool」層左邊框的距離,因為距其左邊最近的是 “tool” 層的左邊框。
「重置」按鈕的 offsetLeft 指「重置」按鈕距「提交」按鈕右邊框的距離,因為距其左邊最近的是「提交」按鈕的右邊框。


offsetTop 可以得到HTML 元素距離上方或外層元素的位置,style.top 也是可以的,二者的區別是:

一、offsetTop 回傳的是數字,而style.top 回傳的是字串,除了數字外還帶有單位:px。
二、offsetTop 只讀,而 style.top 可讀寫。
三、如果沒有給 HTML 元素指定過 top 樣式,則 style.top 傳回的是空字串。

offsetLeft 與 style.left、offsetWidth 與 style.width、offsetHeight 與 style.height 也是同樣道理。

scrollHeight: 取得物件的滾動高度。
scrollLeft:設定或取得位於物件左邊界與視窗中目前可見內容的最左端之間的距離
scrollTop:設定或取得位於物件最頂端與視窗中可見內容的最頂端之間的距離
scrollWidth:取得物件的捲動寬度
offsetHeight:取得物件相對於版面或由父座標offsetParent 屬性指定的父座標的高度
offsetLeft:取得物件相對於版面或由offsetParent 屬性指定的父座標的計算左側位置
offsetTop:取得物件相對於版面或由offsetTop 屬性指定的父座標的計算頂端位置
event.clientX 相對文件的水平座標
event.clientY 相對文件的垂直座標

event.offsetX 相對容器的水平座標
event.offsetY 相對容器的垂直座標
document.documentElement.scrollTop 垂直方向捲動的值
event.clientX document.documentElement.scrollTop 相對.文檔的水平座標垂直方向滾動的量
以上主要指IE之中,FireFox差異如下: 複製代碼

程式碼如下:


IE6.0、FF1.06 :
clientWidth = width pad6.0、FF1.06 :
clientWidth = width pad0Width = wid clientHeight = height padding
padWidight height padding border
IE5.0/5.5:
clientWidth = width - border
clientHeight = height - border
offsetWidth = width
offsetHeight需要提一下:CSS中的margin屬性,與clientWidth、offsetWidth、clientHeight、offsetHeight皆無關)
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn