ホームページ  >  記事  >  ウェブフロントエンド  >  offsetHeight、clientHeight、scrollHeight_javascript スキルの違いを解析する

offsetHeight、clientHeight、scrollHeight_javascript スキルの違いを解析する

WBOY
WBOYオリジナル
2016-05-16 17:13:561051ブラウズ

在网上搜了一下,结论非常笼统,讲IE从不讲版本,因此自己做了测试并上传结论。以下结论皆是在标准模式下测试通过的,没有测试quirk模式。

clientHeight

大部分浏览器对 clientHeight 都没有什么异议,都认为是内容可视区域的高度,也就是说页面浏览器中可以看到内容的这个区域的高度,即然是指可看到内容的区域,滚动条不算在内。但要注意padding是算在内。其计算方式为clientHeight = topPadding + bottomPadding+ height - scrollbar.height。

offsetHeight
在IE6,IE7,IE8以及最新的的FF, Chrome中,在元素上都是offsetHeight = clientHeight + 滚动条 + 边框。

scrollHeight
scrollHeight是元素的padding加元素内容的高度。这个高度与滚动条无关,是内容的实际高度。

计算方式 :scrollHeight = topPadding + bottomPadding + 内容margix box的高度。


在浏览器中的区别在于:

IE6、IE7 认为scrollHeight 是网页内容实际高度,可以小于clientHeight。

FF、Chrome 认为scrollHeight 是网页内容高度,不过最小值是clientHeight。

注: 以上都是对于一般元素而方言的,body和documentElement的clientHeight, offsetHeight和scrollHeight在各个浏览器中的计算方式又不同。在所有的浏览器中,如果你想获取整个视窗的高度,你得用documentElement.clientHeight,因为body.clientHeight是由它的内容决定的。 关于body和documentElement的这些属性,则完全是另外一回事:


FF19

在body上设置overflow:scroll就是设置浏览器的滚动条,导致body.clientHeight永远都等于body.scrollHeight。

body
clientHeight:body.padding+ body.height(css设置或内容撑的);

offsetHeight:clientHeight+ body.border;

scrollHeight== clientHeight。

documentElement
clientHeight= window视窗高度 -scrollbar.width。

offsetHeight= body.offsetHeight  + body.margin。

scrollHeight= 内容的高度(与body的height样式无关),但最小值是documentElement.clientHeight。

元素上
offsetHeight= padding + border + height。

clientHeight= padding + height - scrollbar.width。

scrollHeight>= clientHeight

从结果分析,FF认为scrollHeight的最小高度是clientHeight。

offsetLeft = 元素border左上角到window视窗原点的距离 或 到offsetParent的borderbox顶部的距离。

Chrome
body
clientHeight= body.padding + body.height(css设置或内容撑大);

offsetHeight = body.clientHeight + body.border;

scrollHeight= body.padding + 内容的高度(与height样式无关),但最小值是documentElement.clientHeight。

documentElement
clientHeight= window视窗高度 – 滚动条高度。

offsetHeight  = body.offsetHeight + body.margin;

scrollHeight  = 内容的高度(与body上的height无关),但最小值是documentElement.offsetHeight。

元素上
offsetHeight = padding + border + height。

clientHeight = padding + height - scrollbar.width。

scrollHeight >= clientHeight

Safari 5
body
clientHeight= body.padding + body.height(CSS或内容撑的);

offsetHeight= clientHeight + border;

scrollHeight= body.padding + 内容的高度(与height样式无关),但最小值是documentElement.clientHeight。

documentElement
clientHeight = window窗口大小 – 滚动条大小

offsetHeight = body.offsetHeight + body.margin

scrollHeight= 内容的高度(与body上的height无关),但最小值是documentElement.offsetHeight。

IE8
在IE8下,滚动条的大小是17个像素。

body
clientHeight= body.padding + body.height(css设置或内容撑大)

offsetHeight = clientHeight + body.border

scrollHeight =内容的高度(与body上的height无关),但最小值是clientHeight。

documentElement
clientHeight = 窗口大小(除去滚动条后)

offsetHeight = clientHeight + 滚动条大小 + body.border

scrollHeight=内容的高度(与body上的height无关),但最小值是body.offsetHeight+ margin。

元素上
offsetHeight = padding + border + height。

clientHeight = padding + height - scrollbar.width。

scrollHeight >= clientHeight

从结果分析,FF认为scrollHeight的最小高度是clientHeight。

offsetLeft = 要素の境界線の左上隅からキャンバスの原点までの距離、または offsetParent の境界ボックスの上部からの距離。

IE7
IE7では、本体に設定されているスクロールバーはウィンドウのスクロールバーではありませんので注意が必要です。

body
clientHeight= body.padding 高さ (CSS 設定またはコンテンツ展開) – 本文のスクロール バー。

offsetHeight= clientHeight スクロール バーのサイズ body.border。

scrollHeight= コンテンツの高さ (本体の高さに関係なく)。

documentElement
clientHeight = ウィンドウ サイズ (スクロール バーの有無に関係ありません)

オフセット高さ = クライアントの高さ。

scrollHeight = body.offsetHeight border.margin

要素
offsetHeight = パディング境界線の高さ。

clientHeight = パディングの高さ - スクロールバーの幅。

scrollHeight = パディングコンテンツのマージンボックスの高さ

結果分析から、IE7 は、scrollHeight が clientHeight よりも小さい可能性があると考えています。

offsetLeft = 要素の境界ボックスの左上隅から親コンテナーの境界ボックスの左上隅までの距離 (offsetParent ではありません)。

IE6
IE6でもIE7と同様に、本体に設定されているスクロールバーはウィンドウのスクロールバーではありません。

body
clientHeight = body.padding body.height

offsetHeight = body.clientHeight body.border 本文のスクロール バーのサイズ。

scrollHeight = コンテンツの高さ (本体の高さに関係なく)。

documentElement
IE6 では、IE7 と同様に、本文に設定されているスクロール バーはウィンドウのスクロール バーではありませんが、clientHeight と offsetHeight は他のブラウザーと一貫しています。

clientHeight = ウィンドウ サイズ (ウィンドウ スクロール バーのサイズを削除した後)

offsetHeight =clientHeight body.border

scrollHeight = body.offsetHeight body.margin

要素
offsetHeight = パディング境界線の高さ。

clientHeight = パディングの高さ - スクロールバーの幅。

scrollHeight = パディングコンテンツマージンボックスの高さ

結果分析から、IE6 は、scrollHeight が clientHeight より小さくてもよいと考えています。

同様に

clientWidth、offsetWidth、scrollWidth の説明は上記と同じですが、高さを幅に置き換えるだけです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。