首頁 >web前端 >js教程 >js中的如何定位固定層的位置_javascript技巧

js中的如何定位固定層的位置_javascript技巧

WBOY
WBOY原創
2016-05-16 16:44:311217瀏覽

需要取得一些HTML的物件的座標來更靈活的設定目標層的座標,這裡可以透過用到document.body.scrollTop等屬性,但是這些屬性在xhtml的標準網頁中或更簡單的說就是帶..>的標籤中得到的值是0;如果不要此標籤則一切正常,那麼在xhtml中如何取得body的座標呢?當然有辦法了,我們使用document.documentElement來取代document.body例如可以這樣寫:

複製程式碼 程式碼如下:

var top=document.documentElement.scrollTop ||document.body.scroolTop;

js中的||是個好東西,不但可以用在if的條件語句中,而且還可以用在變數的賦值上,上例可以寫成如下格式:
複製程式碼 程式碼如下:

var top=document.documentElement.scrollTop ?document.documentElement.scrollTop : document.body.scrollTop;

這樣寫可以有很好的相容性。還要注意的一點是:如果不宣告document.documentElement.scrollTop的值反而會顯示0。

js中的如何定位固定層的位置_javascript技巧

說明要想取得目前頁面上捲軸座標的縱座標位置:用
document.documentElement.scrollTop而不是用
document.body.scrollTop ;
document.documentElement取得的是html標籤,
document.body取得的是body標籤;
在標準w3c下,document.body.scrollTop恆為0,需要用document.documentElement.scrollTop來取代;
如果我們要定位滑鼠相對於頁面的絕度位置時,會在搜尋引擎中得到的大多會讓你用
event.clientX document.body.scrollLeft ,event.clientY document.body. scrollTop;
如果發現老鼠偏離了你的想像,一點都奇怪,因為IE5.5之後就不在支援document.body.scrollX物件了
所以我們要加上一句;
複製程式碼 程式碼如下:

if (document.body && document.body.scrollTop &&document.body <.kdocument>{
top=document.body.scrollTop;
left=document.body.scrollleft;
}
if (document.documentElement && document.documentElement.scrollTop&&t. >{
top=document.documentElement.scrollTop;
left=document.documentElement.scrollLeft;
}


下面介紹一些參數的用法:
網頁的可見區域寬度:document.body.clientWidth;
網頁的可見區域高度:document.body.clientHeight;
網頁可見區域寬:document.body.offsetWidth;(包括邊線的寬);
網頁可見區域高:document.body.offsetHeight;(包括邊線的寬);
網頁正文全文寬:document.body.scrollWidth;
網頁正文全文高:document.body.scrollHeight;
網頁被捲去的高:document.body.scrollTop;
網頁被捲去的左:document.body.scrollLeft;
網頁正文部分上:windows.screenTop;
網頁正文部分左:windows.screenLeft;
螢幕解析度的高:windows.screen.height;
螢幕解析度的寬度:windows.screen.widht;
螢幕可用工作區高度:windows.screen.availHeight;
螢幕可用工作區寬度:windows.screen.availWidth;
取得物件的滾動高度:scrollHeight;
設定或取得位於物件左邊界與視窗中目前可見內容的最左端之間的距離:scrollLeft;
設定或取得位於物件最頂端和視窗中可見內容的最頂端之間的距離:scrollTop;
取得物件的捲動寬度:scrollWidth;
取得物件相對於版面或由父座標:offsetParent 屬性指定的捲動寬度:scrollWidth;
取得物件相對於版面或由父座標:offsetParent 屬性指定的父座標的高度:offsetHeight;
取得物件相對於版面或由offsetParent 屬性指定的父座標的計算左側位置:offsetLeft;
取得物件相對於版面或由offsetTop 屬性指定的父座標的計算頂端位置:offsetTop;
event.clientX:相對於文件的水平座標;
event.clientY: 相對於文件的垂直座標;
event.offsetX:相對於容器的水平座標;
event .offsetY:相對於容器的垂直座標;
document.documentElement.scrollTop:設定滾動的垂直高度
event.clientX document.documentElement.scrollTop:相對文檔的水平位置垂直方向的滾動量;
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn