CSS中瀏覽器對(duì)尺寸和寬高解釋差異的解決方法
發(fā)布時(shí)間:2011-01-18 14:25:01 作者:佚名
我要評(píng)論

不同的瀏覽器對(duì)margin、padding、height、width 等屬性的解釋有很大的偏差。有時(shí)我們發(fā)現(xiàn)同樣的兩列布局,在不同的瀏覽器中兩列長(zhǎng)短不一,類(lèi)似的情況太多了,如此困擾大家的麻煩,如何解決?
先看一個(gè)例子
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml”>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″ />
<title>無(wú)標(biāo)題文檔</title>
<style>
#m{height:300px;width:300px;background:#ccc}
#a{float:left;height:100px;width:100px;background:#f00;}
#b{float:left;height:100px;*height:110px;_height:120px;width:100px;background:#0f0;}
#c{clear:both;height:100px;width:100px;*width:100px;_width:120px;background:#00f;}
</style>
</head>
<body>
<div id=”m”>
<div id=”a”></div>
<div id=”b”></div>
<div id=”c”></div>
</div>
</body>
</html>
在這里,height我分別定義了三個(gè),
第一個(gè)正常定義,在所有瀏覽器中都會(huì)生效;
第二個(gè)定義在前邊加了一個(gè)*號(hào),這個(gè)在IE6,IE7中會(huì)正常識(shí)別為height屬性,但是火狐和IE8會(huì)認(rèn)為這是一個(gè)錯(cuò)誤語(yǔ)法,被忽略,而根據(jù)先后執(zhí)行的順序,在IE6和IE7中帶*號(hào)的height被執(zhí)行,那么第一個(gè)正常height失效(或者說(shuō)被覆蓋);
第三個(gè)height在前邊加了一個(gè)下劃線(xiàn),下劃線(xiàn)只有IE6認(rèn)為是有效的height屬性,而IE7 IE8和火狐都視為”_height”屬性是一個(gè)不存在的屬性,所以不予執(zhí)行,而IE6則將其執(zhí)行。這樣前兩個(gè)height在IE6中時(shí)就被帶下劃線(xiàn)的height覆蓋。
那么,通過(guò)這樣一個(gè)例子,您應(yīng)該了解,如果我們想在不通的瀏覽器中分別設(shè)置一個(gè)元素不通的高度的時(shí)候,就可以使用 * 和 _ 兩個(gè)符號(hào)來(lái)協(xié)助定義。同時(shí)我們也了解了,微軟是一個(gè)對(duì)錯(cuò)誤容忍度多高的企業(yè)呀!.呵呵。
不過(guò),如果把這個(gè)例子的前邊兩行文檔類(lèi)型和命名空間的聲明取消掉的話(huà) 帶下劃線(xiàn)的height也會(huì)被正常顯示。
width的設(shè)置是相同的。
我們?cè)趯?shí)際的工作中,更多的會(huì)遇到瀏覽器們對(duì)margin屬性解釋的不一樣,那么這時(shí)星號(hào)和下劃線(xiàn)就能夠幫上大忙。
復(fù)制代碼
代碼如下:<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml”>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″ />
<title>無(wú)標(biāo)題文檔</title>
<style>
#m{height:300px;width:300px;background:#ccc}
#a{float:left;height:100px;width:100px;background:#f00;}
#b{float:left;height:100px;*height:110px;_height:120px;width:100px;background:#0f0;}
#c{clear:both;height:100px;width:100px;*width:100px;_width:120px;background:#00f;}
</style>
</head>
<body>
<div id=”m”>
<div id=”a”></div>
<div id=”b”></div>
<div id=”c”></div>
</div>
</body>
</html>
在這里,height我分別定義了三個(gè),
第一個(gè)正常定義,在所有瀏覽器中都會(huì)生效;
第二個(gè)定義在前邊加了一個(gè)*號(hào),這個(gè)在IE6,IE7中會(huì)正常識(shí)別為height屬性,但是火狐和IE8會(huì)認(rèn)為這是一個(gè)錯(cuò)誤語(yǔ)法,被忽略,而根據(jù)先后執(zhí)行的順序,在IE6和IE7中帶*號(hào)的height被執(zhí)行,那么第一個(gè)正常height失效(或者說(shuō)被覆蓋);
第三個(gè)height在前邊加了一個(gè)下劃線(xiàn),下劃線(xiàn)只有IE6認(rèn)為是有效的height屬性,而IE7 IE8和火狐都視為”_height”屬性是一個(gè)不存在的屬性,所以不予執(zhí)行,而IE6則將其執(zhí)行。這樣前兩個(gè)height在IE6中時(shí)就被帶下劃線(xiàn)的height覆蓋。
那么,通過(guò)這樣一個(gè)例子,您應(yīng)該了解,如果我們想在不通的瀏覽器中分別設(shè)置一個(gè)元素不通的高度的時(shí)候,就可以使用 * 和 _ 兩個(gè)符號(hào)來(lái)協(xié)助定義。同時(shí)我們也了解了,微軟是一個(gè)對(duì)錯(cuò)誤容忍度多高的企業(yè)呀!.呵呵。
不過(guò),如果把這個(gè)例子的前邊兩行文檔類(lèi)型和命名空間的聲明取消掉的話(huà) 帶下劃線(xiàn)的height也會(huì)被正常顯示。
width的設(shè)置是相同的。
我們?cè)趯?shí)際的工作中,更多的會(huì)遇到瀏覽器們對(duì)margin屬性解釋的不一樣,那么這時(shí)星號(hào)和下劃線(xiàn)就能夠幫上大忙。
相關(guān)文章
15 個(gè)為編程初學(xué)者準(zhǔn)備的網(wǎng)站(都是國(guó)外的一些網(wǎng)站)
今天的文章,我們將分享15個(gè)可以學(xué)習(xí)編程的網(wǎng)站,這些網(wǎng)站上提供了很多編程教程,圖書(shū)以及編程練習(xí),希望對(duì)你有用2024-11-02web開(kāi)發(fā)中的長(zhǎng)度單位小結(jié)
這篇文章主要介紹了web開(kāi)發(fā)中的長(zhǎng)度單位主要包括px,pt,em等,需要的朋友可以參考下2023-08-06網(wǎng)頁(yè)前端開(kāi)發(fā)的一些尺寸單位(px,rem單位)
px單位是絕對(duì)單位,一般用于pc端網(wǎng)頁(yè)開(kāi)發(fā),因?yàn)槭墙^對(duì)單位所以在移動(dòng)端上的使用體驗(yàn)并不是很好,rem它是描述相對(duì)于當(dāng)前根元素字體尺寸,是相對(duì)單位,它可以根據(jù)根元素的變換而2023-08-06WEB前端優(yōu)化必備js/css壓縮工具YUI-compressor詳解與集成用法
壓縮工具層次不窮,各有優(yōu)點(diǎn),選擇適合的壓縮工具為將來(lái)做項(xiàng)目開(kāi)發(fā)使用是一件很重要的事情??!在這介紹YUI-compressor,需要的朋友可以參考下2023-06-21html,css,javascript是怎樣變成頁(yè)面的
瀏覽器是多進(jìn)程的,有瀏覽器主進(jìn)程,網(wǎng)絡(luò)進(jìn)程,渲染進(jìn)程,插件進(jìn)程等,在將html,css,javascript解析成一個(gè)頁(yè)面的時(shí)候,就需要多個(gè)進(jìn)程的分工合作2023-05-01- 本文為大家整理了常用的文件對(duì)應(yīng)的MIME類(lèi)型,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-25
postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別介紹
這篇文章介紹了postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-28網(wǎng)頁(yè)中使用Unicode字符的介紹(&#,\u等)
國(guó)際組織制定了可以容納世界上所有文字和符號(hào)的字符編碼方案,稱(chēng)為Unicode,是通用字符集Universal Character Set的縮寫(xiě),用以滿(mǎn)足跨語(yǔ)言、跨平臺(tái)進(jìn)行文本轉(zhuǎn)換、處理的要求2021-11-27前端實(shí)現(xiàn)字符串GBK與GB2312的編解碼(小結(jié))
這篇文章主要介紹了前端實(shí)現(xiàn)字符串GBK與GB2312的編解碼(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2020-12-02告別硬編碼讓你的前端表格自動(dòng)計(jì)算的實(shí)例代碼
這篇文章主要介紹了告別硬編碼讓你的前端表格自動(dòng)計(jì)算,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-27