元素邊框外側相對于父容器的邊框外側的高度
專業(yè)領域包括做網站、成都網站設計、商城建設、微信營銷、系統(tǒng)平臺開發(fā), 與其他網站設計及系統(tǒng)開發(fā)公司不同,成都創(chuàng)新互聯(lián)公司的整合解決方案結合了幫做網絡品牌建設經驗和互聯(lián)網整合營銷的理念,并將策略和執(zhí)行緊密結合,為客戶提供全網互聯(lián)網整合方案。
chrome firefox ie
原生
offsetTop 元素邊框外側相對于父容器的邊框內側的高度 元素邊框外側相對于父容器的邊框內側的高度 元素邊框外側相對于父容器的邊框內側的高度
offsetHeight 元素的高度(包括padding和border) 元素的高度(包括padding和border) 元素的高度(包括padding和border)
scrollHeight 元素內容實際高度 元素內容實際高度 元素內容實際高度
clientHeight 元素可見區(qū)域高度(包括padding) 元素可見區(qū)域高度(包括padding) 元素可見區(qū)域高度(包括padding)
clientTop 元素上邊框高度 元素上邊框高度 元素上邊框高度
scrollTop 元素滾動了的高度 元素滾動了的高度 元素滾動了的高度
jquery
offset().top 獲取元素距離文檔頂部高度 獲取元素距離文檔頂部高度 獲取元素距離文檔頂部高度
position().top 元素margin外側相對于父容器的邊框內側的高度 元素margin外側相對于父容器的邊框內側的高度 元素margin外側相對于父容器的邊框內側的高度
height() 元素實際高度 元素實際高度 元素實際高度
innerHeight() 元素高度(包括padding) 元素高度(包括padding) 元素高度(包括padding)
outerHeight() 元素高度(包括padding、border) 元素高度(包括padding、border) 元素高度(包括padding、border)
outerHeight(true) 元素高度(包括padding、border、margin) 元素高度(包括padding、border、margin) 元素高度(包括padding、border、margin)
scrollTop() 元素滾動了的高度 元素滾動了的高度 元素滾動了的高度
窗口、文檔高度
$(window).height() 窗口可見區(qū)域高度 窗口可見區(qū)域高度 窗口可見區(qū)域高度
document.documentElement.clientHeight 文檔可見區(qū)域高度 文檔可見區(qū)域高度 文檔可見區(qū)域高度
window.screen.height 屏幕分辨率高度 屏幕分辨率高度 屏幕分辨率高度
window.screen.availHeight 屏幕可用高度(屏幕高度除去底部任務欄) 屏幕可用高度(屏幕高度除去底部任務欄) 屏幕可用高度(屏幕高度除去底部任務欄)
window.screenY 窗口距離屏幕頂部高度 窗口距離屏幕頂部高度 窗口距離屏幕頂部高度
window.screenTop 窗口距離屏幕頂部高度 無此屬性 窗口距離屏幕頂部高度
$document.height() 文檔高度 文檔高度 文檔高度
document.documentElement.scrollHeight 文檔內容高度 文檔內容高度 文檔內容高度
document.body.scrollHeight body內容高度 body內容高度 body內容高度
注意:
offsetTop 父容器必須設置了relative或者是absolute,否則會一直往上找設置了兩者的祖先元素,chrome和ie最終返回距離文檔頂部的高度,火狐返回的是距離body元素外邊框的高度。
position也是一樣,不過三個瀏覽器最后都返回的是距離文檔頂部的高度。
通常情況下
$document.height()=document.documentElement.scrollHeight=document.body.scrollHeight=$body.outerHeight(true)
$(window).scrollTop()=$(document).scrollTop()=window.scrollY=document.body.scrollTop=
window.pageYOffset
$el.outerHeight()=$el[0].offsetHeight;
$(window).height()=document.documentElement.clientHeight;
$el.innerHeight()=$el[0].clientHeight;
$el.scrollTop()=$el[0].scrollTop;
在代碼中如果要用到高度的時候最好使用offsetHeight或者outerHeight()。
窗口滾動到底部:窗口高度+滾動了的高度=文檔高度。
元素滾動到底部:元素可見高度+滾動了的高度=元素內容高度。
瀏覽器差異
offsetHeight
IE、Opera 認為 offsetHeight = clientHeight + 滾動條 + 邊框。
NS、FF 認為 offsetHeight 是網頁內容實際高度,可以小于 clientHeight。
scrollHeight
IE、Opera 認為 scrollHeight 是網頁內容實際高度,可以小于 clientHeight。
NS、FF 認為 scrollHeight 是網頁內容高度,不過最小值是 clientHeight。
簡單地說
clientHeight 就是透過瀏覽器看內容的這個區(qū)域高度。
NS、FF 認為 offsetHeight 和 scrollHeight 都是網頁內容高度,只不過當網頁內容高度小于等于 clientHeight 時,scrollHeight 的值是 clientHeight,而 offsetHeight 可以小于 clientHeight。
IE、Opera 認為 offsetHeight 是可視區(qū)域 clientHeight 滾動條加邊框,scrollHeight 則是網頁內容實際高度。
window 和 document使用height代替innerHeight和outerHeight
鼠標事件:
clientX 設置或獲取鼠標指針位置相對于當前窗口的 x 坐標,其中客戶區(qū)域不包括窗口自身的控件和滾動條。
clientY 設置或獲取鼠標指針位置相對于當前窗口的 y 坐標,其中客戶區(qū)域不包括窗口自身的控件和滾動條。
offsetX 設置或獲取鼠標指針位置相對于觸發(fā)事件的對象的 x 坐標。
offsetY 設置或獲取鼠標指針位置相對于觸發(fā)事件的對象的 y 坐標。
screenX 設置或獲取獲取鼠標指針位置相對于用戶屏幕的 x 坐標。
screenY 設置或獲取鼠標指針位置相對于用戶屏幕的 y 坐標。
x 設置或獲取鼠標指針位置相對于父文檔的 x 像素坐標(亦即相對于當前窗口)。
y 設置或獲取鼠標指針位置相對于父文檔的 y 像素坐標(亦即相對于當前窗口)。
總結:
document.documentElement是html元素,document.body是body元素,document.body.scrollHeight就是文檔的總共高度,不是body的總共高度
原生js的 style屬性只能獲取到行內的樣式信息,定義在 css中的是無法獲取到的,如果需要獲取的話用 document.defaultView.getComputedStyle(obj,null)[attr];