對于某些內(nèi)容可變的層(比如用戶評論),我們希望它有個最小的高度 (比如30px),這樣的話,即使內(nèi)容只有一行字,也不會太難看;同時又希望在內(nèi)容比較多的時候,層的高度能自動撐開,也就是要求height: auto。這時候就可以設(shè)置css的min-height屬性。min-height在Firefox里有效,但IE無法識別。 可以使用下面這個解決方案:
.div_class{
min-height:30px;
height:auto !important;
height:30px;
}
第一行設(shè)置 min-height:30px;對Firefox有效;第二行height:auto !important;也對Firefox有效,后面緊跟的“!important”是Firefox專用的一個標記,帶有這個標記的設(shè)置具有最高優(yōu)先 級,之后的設(shè)置都無效。所以第三行的height:30px對Firefox無效了;同時,由于IE無法識別min-height和“! important”,所以只有第三行有效,由于IE默認就是高度自適應的,所以即使設(shè)置了30px的高度,只要內(nèi)容很多,也會自動撐開,不需要設(shè)置 height:auto。最后,上述代碼產(chǎn)生如下效果:
對于Firefox,等同于:
.div_class{
min-height:30px;
height:auto;
}
對于IE,等同于:
.div_class{
height:30px;
}
“!important” 是個非常好用的東西,如果你寫過幾個月的跨瀏覽器的CSS代碼,就很容易被Firefox和IE之間的差別而感到惱火。比如padding屬性就是一個例子。
假設(shè)這樣一個層:
.div_name {
width:100px;
padding:10px;
}
在IE里面,層的寬度是100px,四周的余空為10px;但是對于Firefox,層的寬度變成了100px+10px+10px=120px,對于寬度敏感的設(shè)計來說,整個就混亂了。怎么辦呢?還是求助于“!important”吧。只要這樣寫就可以了:
.div_name {
width:80px !important;
width:100px;
padding:10px;
}
因為80+10+10=100。正好讓寬度 變成100px。
有時候,我們給一個層加上邊框 ,在Firefox里面也會出現(xiàn)寬度增加的情況,比如:
.div_name {
width:100px;
padding:10px;
border:2px solid #ccc;
}
上面這個層,在Firefox里面的實際寬度等于100+10+10+2+2=124px,因為邊框也會增加寬度。怎么辦呢,還是靠“!important”,這樣寫就可以了:
.div_name {
width:76px !important;
width:100px;
padding:10px;
border:2px solid #ccc;
}
新聞熱點
疑難解答