詳解clientHeight、offsetHeight、scrollHeight
來源:互聯網
上載者:User
關於clientHeight、offsetHeight、scrollHeightwindow.screen.availWidth 返回當前螢幕寬度(空白空間) window.screen.availHeight 返回當前螢幕高度(空白空間) window.screen.width 返回當前螢幕寬度(解析度值) window.screen.height 返回當前螢幕高度(解析度值) window.document.body.offsetHeight; 返回當前網頁高度 window.document.body.offsetWidth; 返回當前網頁寬度 我們這裡說說四種瀏覽器對 document.body 的 clientHeight、offsetHeight 和 scrollHeight 的解釋。這四種瀏覽器分別為IE(Internet Explorer)、NS(Netscape)、Opera、FF(FireFox)。clientHeight大家對 clientHeight 都沒有什麼異議,都認為是內容可視地區的高度,也就是說頁面瀏覽器中可以看到內容的這個地區的高度,一般是最後一個工具條以下到狀態列以上的這個地區,與頁面內容無關。offsetHeightIE、Opera 認為 offsetHeight = clientHeight + 捲軸 + 邊框。NS、FF 認為 offsetHeight 是網頁內容實際高度,可以小於 clientHeight。scrollHeightIE、Opera 認為 scrollHeight 是網頁內容實際高度,可以小於 clientHeight。NS、FF 認為 scrollHeight 是網頁內容高度,不過最小值是 clientHeight。簡單地說clientHeight 就是透過瀏覽器看內容的這個地區高度。NS、FF 認為 offsetHeight 和 scrollHeight 都是網頁內容高度,只不過當網頁內容高度小於等於 clientHeight 時,scrollHeight 的值是 clientHeight,而 offsetHeight 可以小於 clientHeight。IE、Opera 認為 offsetHeight 是可視地區 clientHeight 捲軸加邊框。scrollHeight 則是網頁內容實際高度。同理clientWidth、offsetWidth 和 scrollWidth 的解釋與上面相同,只是把高度換成寬度即可。=======================================================================clientHeight與offsetHeight的區別許多文章已經介紹了clientHeight和offsetHeight的區別,就是clientHeight的值不包括scrollbar的高度,而offsetHeight的值包括了scrollbar的高度。然而,clientHeight和offsetHeight的值到底由什麼組成的呢?如何計算這兩個數的值?1. clientHeight和offsetHeight的值由什麼決定?假如我們有以下的DIV,主要顯示的文字為"This is the main body of DIV"。如所示,clientHeight的值由DIV內容的實際高度和CSS中的padding值決定,而offsetHeight的值由DIV內容的實際高度,CSS中的padding值,scrollbar的高度和DIV的border值決定;至於CSS中的margin值,則不會影響clientHeight和offsetHeight的值。2. CSS中的Height值對clientHeight和offsetHeight有什麼影響?首先,我們看一下CSS中Height定義的是什麼的高度。如在本文最後部分“APPENDIX範例程式碼”(註:以下稱為“範例程式碼”)中,innerDIVClass的Height值設定為50px,在IE下計算出來的值如下所示。也就是說,在IE裡面,CSS中的Height值定義了DIV包括padding在內的高度(即offsetHeight的值);在Firefox裡面,CSS中的Height值只定義的DIV實際內容的高度,padding並沒有包括在這個值裡面(70 = 50 + 10 * 2)。in IE: innerDiv.clientHeight: 46innerDiv.offsetHeight: 50outerDiv.clientHeight: 0outerDiv.offsetHeight: 264in Firfox:innerDiv.clientHeight: 70innerDiv.offsetHeight: 74outerDiv.clientHeight: 348outerDiv.offsetHeight: 362在上面的樣本中,也許你會很奇怪,為什麼在IE裡面outerDiv.clientHeight的值為0。那是因為範例程式碼中,沒有定義outerDIVClass的Height值,這時,在IE裡面,則clientHeight的值是無法計算的。同樣,在範例程式碼中,如果將innerDIVClass中的Height值去年,則innerDIV.clientHeight的值也為0。(註:在Firefox下不存在這種情況)。如果CSS中Height值小於DIV要顯示內容的高度的時候呢(當CSS中沒有定義overflow的行為時)?在IE裡面,整個clientHeight(或者offsetHeight)的值並沒有影響,DIV會自動被撐大;而在Firefox裡面,DIV是不會被撐開的。如在範例程式碼中,將innerDivClass的Height值設為0,則計算結果如下所示。IE裡面的DIV被撐開,其clientHeight值等於內容的高度與padding*2的和;而Firefox裡面,文字將溢出DIV的邊界,其clientHeight值正好是padding值的兩倍。In IE:innerDiv.clientHeight: 38innerDiv.offsetHeight: 42outerDiv.clientHeight: 0outerDiv.offsetHeight: 256In Firefox:innerDiv.clientHeight: 20innerDiv.offsetHeight: 24outerDiv.clientHeight: 298outerDiv.offsetHeight: 312