important的妙用解決firefox和ie的css兼容問題
發(fā)布時間:2014-04-18 11:08:50 作者:佚名
我要評論
設(shè)置css的min-height屬性。min-height在Firefox里有效,但IE無法識別。下面有個不錯的解決方案,大家可以參考下
對于某些內(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專用的一個標(biāo)記,帶有這個標(biāo)記的設(shè)置具有最高優(yōu)先 級,之后的設(shè)置都無效。所以第三行的height:30px對Firefox無效了;同時,由于IE無法識別min-height和“! important”,所以只有第三行有效,由于IE默認就是高度自適應(yīng)的,所以即使設(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;
}
復(fù)制代碼
代碼如下:.div_class{
min-height:30px;
height:auto !important;
height:30px;
}
第一行設(shè)置 min-height:30px;對Firefox有效;第二行height:auto !important;也對Firefox有效,后面緊跟的“!important”是Firefox專用的一個標(biāo)記,帶有這個標(biāo)記的設(shè)置具有最高優(yōu)先 級,之后的設(shè)置都無效。所以第三行的height:30px對Firefox無效了;同時,由于IE無法識別min-height和“! important”,所以只有第三行有效,由于IE默認就是高度自適應(yīng)的,所以即使設(shè)置了30px的高度,只要內(nèi)容很多,也會自動撐開,不需要設(shè)置 height:auto。最后,上述代碼產(chǎn)生如下效果:
對于Firefox,等同于:
復(fù)制代碼
代碼如下:.div_class{
min-height:30px;
height:auto;
}
對于IE,等同于:
復(fù)制代碼
代碼如下:.div_class{
height:30px;
}
“!important” 是個非常好用的東西,如果你寫過幾個月的跨瀏覽器的CSS代碼,就很容易被Firefox和IE之間的差別而感到惱火。比如padding屬性就是一個例子。
假設(shè)這樣一個層:
復(fù)制代碼
代碼如下:.div_name {
width:100px;
padding:10px;
}
在IE里面,層的寬度是100px,四周的余空為10px;但是對于Firefox,層的寬度變成了100px+10px+10px=120px,對于寬度敏感的設(shè)計來說,整個就混亂了。怎么辦呢?還是求助于“!important”吧。只要這樣寫就可以了:
復(fù)制代碼
代碼如下:.div_name {
width:80px !important;
width:100px;
padding:10px;
}
因為80+10+10=100。正好讓寬度 變成100px。
有時候,我們給一個層加上邊框 ,在Firefox里面也會出現(xiàn)寬度增加的情況,比如:
復(fù)制代碼
代碼如下:.div_name {
width:100px;
padding:10px;
border:2px solid #ccc;
}
上面這個層,在Firefox里面的實際寬度等于100+10+10+2+2=124px,因為邊框也會增加寬度。怎么辦呢,還是靠“!important”,這樣寫就可以了:
復(fù)制代碼
代碼如下:.div_name {
width:76px !important;
width:100px;
padding:10px;
border:2px solid #ccc;
}
相關(guān)文章
這篇文章主要介紹了淺談原生頁面兼容IE9問題的解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起2020-12-16新版chrome瀏覽器設(shè)置允許跨域的實現(xiàn)
這篇文章主要介紹了新版chrome瀏覽器設(shè)置允許跨域的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起2020-11-30css hack之\9和\0就可能對hack IE11\IE9\IE8無效
每次設(shè)計一張網(wǎng)頁或一個表單,都被各種瀏覽器的兼容問題傷透腦筋,尤其是IE家族。在做兼容性設(shè)計時,我們往往會使用各種瀏覽器能識別的獨特語法進行hack,從而達到各種瀏覽2020-03-20css區(qū)分ie8/ie9/ie10/ie11 chrome firefox的代碼
這篇文章主要介紹了css區(qū)分ie8/ie9/ie10/ie11 chrome firefox的代碼,需要的朋友可以參考下2020-03-20
這篇文章主要介紹了解決CSS瀏覽器兼容性問題的4種方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)2020-02-28
這篇文章主要介紹了常見的瀏覽器兼容性問題(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)2020-02-20
這篇文章主要介紹了border-radius IE8兼容處理的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)2020-02-12- 這篇文章主要介紹了淺談遇到的幾個瀏覽器兼容性問題,詳細的介紹了幾種我遇到的問題和解決方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-26
這篇文章主要介紹了base64圖片在各種瀏覽器的兼容性處理的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-14
這篇文章主要介紹了對常見的css屬性進行瀏覽器兼容性總結(jié)(推薦)的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-20






