important的妙用解決firefox和ie的css兼容問題
發(fā)布時(shí)間:2014-04-18 11:08:50 作者:佚名
我要評(píng)論

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