javascript獲取網(wǎng)頁各種高寬及位置的方法總結(jié)
screen對象
獲取屏幕的高寬(分辨率)
screen.width //屏幕的寬 screen.height //屏幕的高 screen.availWidth //屏幕可用寬度 屏幕的像素高度減去系統(tǒng)部件高度之后的值 screen.availHeight //屏幕可用高度 屏幕的像素寬度減去系統(tǒng)部件寬度之后的值
window對象
獲得窗口位置及大小
window.screenTop //窗口頂部距屏幕頂部的距離 window.screenLeft //窗口左側(cè)距屏幕左側(cè)的距離 window.innerWidth //窗口中可視區(qū)域(viewpoint)的寬度 alert(window.innerWidth); //chrome 1366 ff 1366 ie 1366 window.innerHeight //窗口中可視區(qū)域(viewpoint)的高度 該值與瀏覽器是否顯示菜單欄等因素有關(guān) alert(window.innerHeight); //chrome 643 ff 657 ie 673 window.outerWidth //瀏覽器窗口本身的寬度(可視區(qū)域?qū)挾?瀏覽器邊框?qū)挾? alert(window.outerWidth); //chrome 1366 ff 1382 ie 1382 //說明chrome在最大化時(shí)瀏覽器窗口沒有邊框?qū)挾?非最大化時(shí)有8px邊框 //ff和ie上下左右有8px的邊框?qū)挾? window.outerHeight //瀏覽器窗口本身的高度 alert(window.outerHeight); //chrome 728 ff 744 ie 744
element對象
在介紹element對象各種高寬之前有必要解釋一下盒模型
默認(rèn)盒模型 box-sizing:content-box;
boxWidth = 2*margin + 2*border + 2*padding + width boxHeight = 2*margin + 2*border + 2*padding + height
當(dāng)不出現(xiàn)滾動(dòng)條時(shí)
body{margin:0;} #demo{ width:100px; height:100px; padding:10px; border:20px; margin:30px; background-color:red; } <div id="demo">123456789 123456789</div>
clientWidth:在頁面上返回內(nèi)容的可視寬度(不包括邊框,邊距或滾動(dòng)條)
clientHeight:在頁面上返回內(nèi)容的可視高度(不包括邊框,邊距或滾動(dòng)條)
clientWidth = 2*padding + width - scrollbarWidth console.log(document.getElementById('demo').clientWidth); //120 此時(shí)scrollbarWidth=0 clientHeight = 2*padding + height - scrollbarHeight console.log(document.getElementById('demo').clientHeight); //120 此時(shí)scrollbarWidth=0
offsetWidth:返回元素的寬度包括邊框和填充,但不包括邊距
offsetHeight:返回元素的高度包括邊框和填充,但不包括邊距
offsetWidth = 2*border + 2*padding + width console.log(document.getElementById('demo').offsetWidth) //160 offsetHeight = 2*border + 2*padding + height console.log(document.getElementById('demo').offsetHeight) //160
offsetLeft: 獲取對象相對于版面或由 offsetLeft屬性指定的父坐標(biāo)的計(jì)算左側(cè)位置
offsetTop: 獲取對象相對于版面或由 offsetTop屬性指定的父坐標(biāo)的計(jì)算頂端位置
console.log(document.getElementById('demo').offsetLeft) //30 console.log(document.getElementById('demo').offsetTop) //30
當(dāng)出現(xiàn)滾動(dòng)條時(shí)
body{ margin:0; padding:20px; width:1000px; height:500px; } <div id="demo">123456789123456789</div>
scrollWidth: 返回元素的整個(gè)寬度(包括帶滾動(dòng)條的隱蔽的地方)
scrollHeight: 返回整個(gè)元素的高度(包括帶滾動(dòng)條的隱蔽的地方)
scrollWidth = 2*padding + width console.log(document.body.scrollWidth) //1040 scrollHeight = 2*padding + width console.log(document.body.scrollHeight) //540
scrollTop: 向下滑動(dòng)滾動(dòng)塊時(shí)元素隱藏內(nèi)容的高度。不設(shè)置時(shí)默認(rèn)為0,其值隨著滾動(dòng)塊滾動(dòng)而變化
scrollLeft: 向右滑動(dòng)滾動(dòng)塊時(shí)元素隱藏內(nèi)容的寬度。不設(shè)置時(shí)默認(rèn)為0,其值隨著滾動(dòng)塊滾動(dòng)而變化
event對象
Event 對象代表事件的狀態(tài),比如事件在其中發(fā)生的元素、鍵盤按鍵的狀態(tài)、鼠標(biāo)的位置、鼠標(biāo)按鈕的狀態(tài)。
event.pageX:相對整個(gè)頁面的坐標(biāo),以頁面的左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的水平距離(IE8不支持)
event.pageY:相對整個(gè)頁面的坐標(biāo),以頁面的左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的垂直距離(IE8不支持)
event.clientX:相對可視區(qū)域的坐標(biāo),以瀏覽器可視區(qū)域左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的水平距離
event.clientY:相對可視區(qū)域的坐標(biāo),以瀏覽器可視區(qū)域左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的垂直距離
event.screenX:相對電腦屏幕的坐標(biāo),以屏幕左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的水平距離
event.screenY:相對電腦屏幕的坐標(biāo),以屏幕左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的垂直距離
event.offsetX:相對于自身的坐標(biāo),以自身的padding左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的水平距離
event.offsetY:相對于自身的坐標(biāo),以自身的padding左上角為坐標(biāo)原點(diǎn)到鼠標(biāo)所在點(diǎn)的水平距離
以上這篇javascript獲取網(wǎng)頁各種高寬及位置的方法總結(jié)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- javascript獲取網(wǎng)頁寬高方法匯總
- javascript實(shí)現(xiàn)網(wǎng)頁中涉及的簡易運(yùn)動(dòng)(改變寬高、透明度、位置)
- JS獲取屏幕,瀏覽器窗口大小,網(wǎng)頁高度寬度(實(shí)現(xiàn)代碼)
- javascript獲取和判斷瀏覽器窗口、屏幕、網(wǎng)頁的高度、寬度等
- 獲取JS中網(wǎng)頁各種高寬與位置的方法總結(jié)
- JavaScript獲取網(wǎng)頁、瀏覽器、屏幕高度和寬度匯總
- JS獲取網(wǎng)頁屬性包括寬、高等等
- jQuery javascript獲得網(wǎng)頁的高度與寬度的實(shí)現(xiàn)代碼
- JavaScript獲取網(wǎng)頁的寬高及如何兼容詳解
相關(guān)文章
JavaScript高級(jí)程序設(shè)計(jì)閱讀筆記(六) ECMAScript中的運(yùn)算符(二)
ECMAScript中的運(yùn)算符,學(xué)習(xí)js的朋友可以參考下2012-02-02javascript實(shí)現(xiàn)3D切換焦點(diǎn)圖
一款用JavaScript模仿3D立體切換效果的js焦點(diǎn)幻燈片特效,使用方法很簡單:用鼠標(biāo)拖拽圖片向左右方向就好~2015-10-10Javascript中數(shù)組sort和reverse用法分析
這篇文章主要介紹了Javascript中數(shù)組sort和reverse用法,實(shí)例分析了sort和reverse使用時(shí)的注意事項(xiàng)與相關(guān)技巧,具有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12js 禁用只讀文本框獲得焦點(diǎn)時(shí)的退格鍵
發(fā)現(xiàn)只讀文本框有一個(gè)缺陷,當(dāng)鼠標(biāo)焦點(diǎn)在文本框里面的時(shí)候按回退鍵(backSpace), 會(huì)退回到前一個(gè)頁面2010-04-04JavaScript查看代碼運(yùn)行效率console.time()與console.timeEnd()用法
今天小編就為大家分享一篇關(guān)于JavaScript查看代碼運(yùn)行效率console.time()與console.timeEnd()用法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01怎么選擇Javascript框架(Javascript Framework)
如果你正面臨這樣的問題,希望下面的幾個(gè)建議對你在選擇javascript框架上會(huì)有所幫助2013-11-11JS實(shí)現(xiàn)用戶注冊時(shí)獲取短信驗(yàn)證碼和倒計(jì)時(shí)功能
在用戶注冊時(shí),通常需要短信驗(yàn)證碼,而且為了交互效果,也需要增加倒計(jì)時(shí)。該如何實(shí)現(xiàn)獲取驗(yàn)證碼倒計(jì)時(shí)功能呢?下面小編給大家分享JS實(shí)現(xiàn)用戶注冊時(shí)獲取短信驗(yàn)證碼和倒計(jì)時(shí)的代碼,一起看看吧2016-10-10