首頁  >  文章  >  web前端  >  css中實作相容IE6、IE7、FF的min-height最小高度

css中實作相容IE6、IE7、FF的min-height最小高度

黄舟
黄舟原創
2017-07-21 09:32:011389瀏覽

css中實作相容IE6、IE7、FF的min-height最小高度

#mrjin {
    background:#ccc;    min-height:100px;    /*高度最小值设置为:100px*/
    height:auto !important; /*兼容FF,IE7也支持 !important标签*/
    height:100px; /*兼容ie6*/
    overflow:visible;
}

最大宽度...主流浏览器IE对max-width是不支持的,对这一属性的设置在IE中是无效的。同样的对min-width的设置也是无效的。

#commentlist img {
         width: expression(this.width > 500 ? 500: true); 
         max-width: 500px;
}   
#woaicss {
width:100%;  /*FF来说是有效的。而对于IE则没有作用/*
max-width:500px;
width:expression(document.body.clientWidth > 500? "500px": "auto" );
background:#c00;
margin:0 auto;
line-height:30px;
}

/*expression与Javas cript表达式关联起来,对浏览器要求较高1E5以上使用。不建议常用*/

關於clientHeight、offsetHeight、scrollHeight

window.screen.availWidth      返回目前螢幕寬度(空白空間)
window.screen.availHeight     返回目前螢幕高度(空白空間)  
window.screen.width           返回目前螢幕寬度(解析度值)  
window.screen.height 解析度值返回目前螢幕寬度( 
window.document.body.offsetHeight;     返回目前網頁高度 
window.document.body.offsetWidth;     返回目前網頁寬度 
我們在這裡說四種瀏覽器對document.body 的Height、offsetclientHeight、offsetclientHeight scrollHeight 的解釋。

這四種瀏覽器分別為IE(Internet Explorer)、NS(Netscape)、Opera、FF(FireFox)。
clientHeight
大家對clientHeight 都沒有什麼異議,都認為是內容視覺區域的高度,也就是說頁面瀏覽器中可以看到內容的這個區域的高度,一般是最後一個工具條以下到狀態列以上的這個區域,與頁面內容無關。

offsetHeight
IE、Opera 認為 offsetHeight = clientHeight + 捲軸 + 邊框。
NS、FF 認為 offsetHeight 是網頁內容實際高度,可以小於 clientHeight。

scrollHeight
IE、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: 46 
innerDiv.offsetHeight: 50 
outerDiv.clientHeight: 0 
outerDiv.offsetHeight: 264

in Firfox:

innerDiv.clientHeight: 70 
innerDiv.offsetHeight: 74 
outerDiv.clientHeight: 348 
outerDiv.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: 38 
innerDiv.offsetHeight: 42 
outerDiv.clientHeight: 0 
outerDiv.offsetHeight: 256

In Firefox:

innerDiv.clientHeight: 20 
innerDiv.offsetHeight: 24 
outerDiv.clientHeight: 298 
outerDiv.offsetHeight: 312


APPENDIX 範例程式碼

<html> 
<head> 
<style type="text/css">...... 
.innerDivClass 
{...}{...}{...}{ 
       color: red; 
       margin: 37px; 
       padding: 10px; 
       border: 2px solid #000000; 
       height: 50px; 


} 
.outerDivClass 
{...}{...}{...}{ 
       padding: 100px; 
       margin: 200px; 
       border: 7px solid #000000; 
} 
</style> 

<script>...... 
function checkClientHeight() 
......{ 
      var innerDiv = document.getElementById("innerDiv"); 
      var outerDiv = document.getElementById("outerDiv"); 

       result.innerHTML = "innerDiv.clientHeight: " + innerDiv.clientHeight + "<br />"; 
       result.innerHTML += "innerDiv.offsetHeight: " + innerDiv.offsetHeight + "<br />"; 
       result.innerHTML += "outerDiv.clientHeight: " + outerDiv.clientHeight + "<br />"; 
       result.innerHTML += "outerDiv.offsetHeight: " + outerDiv.offsetHeight + "<br />"; 
} 
</script> 
</head> 
<body> 
<div id="outerDiv" class="outerDivClass"> 
<div class="innerDivClass" id="innerDiv"> 
Hello world.         
</div> 
</div> 
<p></p> 
<div id="result"> 
</div> 
<input type="button" onclick="checkClientHeight()" text="Click Me" Value="Click Me" /> 
</body> 
</html>

以上是css中實作相容IE6、IE7、FF的min-height最小高度的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn