
使用DIV+CSS構架好處不少,但也確實存在一些問題,現在讓網頁設計師最頭疼的事莫過于DIV+CSS對瀏覽器的兼容性了,可能你用慣了IE6,做出來的東西沒感覺到有多大異常,但是把同樣的東西放到IE7里去看的話,就會發現很多問題,如果放到火狐瀏覽器里去看,結果更不盡人意。
一個頁面從制作的開始就決定了他要使用的瀏覽器解析css模式,瀏覽器模式的不同,就造成了各個瀏覽器對頁面顯示的差異。瀏覽器解析css有兩種模式,quirks mode和strict mode,目前正在使用的瀏覽器這兩種模式都支持,在doctype聲明中, 沒有使用DTD聲明或者使用HTML4以下(不包括HTML4)的DTD聲明時,基本所有的瀏覽器都是使用quirks mode呈現,其他的則使用strict mode解析。
這兩種模式最大的不同就是提現在對盒模式的解釋上。什么是盒模式?這是針對塊級元素說的,這里簡單說一下,說白了就是把塊級元素想像成一個裝東西的盒子,而margin,padding,border,width這些css屬性構成了盒模式。而區別就是產生在width屬性上。
在strict mode中:
width是內容寬度 ,也就是說,元素真正的寬度 = margin-left + border-left-width + padding-left + width + padding-right + border-right-width + margin-right;
在quirks mode中:
width則是元素的實際寬度 ,內容寬度 = width - (margin-left + margin-right + padding-left + padding-right + border-left-width + border-right-width)
其他要注意的事項:
·內聯元素 ,例如<a>、<span>等,定義上下邊界不會影響到行高(line-height),內聯元素距離上一行元素的距離由行高決定,而不是填充或邊界。 注2. 內聯元素(display: inline) 內聯元素不需要在新行內顯示,而且也不強迫其后的元素換行,如a、em、span等都為內聯元素。內聯元素可以為任何其他元素的子元素。
·浮動元素(無論左或者右浮動)邊界不壓縮 ,且若浮動元素不聲明寬度,則其寬度趨向于0,即壓縮到其內容能承受的最小寬度。
·如果盒中沒有內容,則即使定義了寬度和高度都為100%,實際上只占0% ,因此不會被顯示,此點在采取層布局的時候需特別注意。
·邊界值可為負,其顯示效果各瀏覽器可能不相同 。
·填充值不可為負 。
·邊框默認的樣式(border-style)為不顯示(none)
下面來說說IE6,IE7及FF火狐瀏覽器的區別和兼容方法:
1. IE7與IE6相比, 有多達200多處改進, 但它們都是在Strict Mode下實現的, 即在頁首聲明DocType為XHTML Transitional, XHTML Strict等. 而在Quirks Mode下, IE7和IE6別無二致。所以為了更好的兼容,盡量聲明DocType,采用Strict Mode進行制作。
2. IE7支持Alpha通道的PNG圖片, 但是這些Alpha通道圖片在IE6下還是不能正常顯示的,所以還是盡量使用透明GIF圖片。
3. IE7盒子模型改變了:盒子對于"overflow"使用了"visible"默認值,所以對于子元素尺寸大于父元素尺寸時, IE7會和Firefox一樣將子元素露出于父元素之外顯示, 而不是像IE6那樣把父元素撐大了包含子元素.把頁面設置成"overflow:visible"即可。
4. 設置為float的div在ie下設置的margin會加倍。這是一個ie6存在的bug。解決方案是在這個div里面加上"display:inline"。
5. IE和火狐對'width'定義的不同:
Firefox中:容器占的寬度=內容寬度+padding寬度+border寬度;
IE中:內容寬度=您定義的容器寬度(Internet Explorer 'width')-padding寬度-border寬度
(Internet Explorer 'width'則是指整個容器的寬度,包括內容,padding ,border)
6. css布局的居中問題:FF火狐里設置margin-left, margin-right 為 auto 時已經居中, IE則設置body {TEXT-ALIGN: center;} 才行
7. FF火狐設置padding后, div會增加height和width, 但IE不會, 故需要用 !important 多設一個height和width
8. 在mozilla firefox和IE中的BOX模型解釋不一致導致相差2px解決方法:div{margin:30px!important;margin:28px;}
9. ul標簽在FF火狐中默認是有padding值的,而在IE中只有margin有值所以先定義ul{margin:0;padding:0;}
10.終結解決方法:
(1)!important:FF火狐和IE7對于"!important"會自動優先解析,IE6則忽略,可用!important為FF火狐和IE7單獨設置樣式,不影響IE6的顯示,值得注意的是,一定要將xxxx !important 這句放置在另一句之上。
示例:div{margin:30px!important;margin:15px;} //在FF火狐和IE7中margin:30px,在IE6中margin:15px;
(2)由于FF火狐和IE7都支持"!important",而二者之間也存在差異,所以有時也會出現一些小問題,針對IE7可以使用使用"*+html",
示例:#example { color: #333; } /* FF火狐下字體顏色顯示為#333 */
* html #example { color: #666; } /* IE6下字體顏色顯示為#666 */
*+html #example { color: #999; } /* IE7下字體顏色顯示為#999 */
其他注意事項:
1. float的div一定要閉合,即清除浮動
示例:(其中floatA、floatB的屬性已經設置為float:left;)
<div>
<div id="floatA"></div>
<div id="floatB"></div>
<div id="NOTfloatC"></div>
</div>
這里的NOTfloatC并不希望繼續平移,而是希望往下排。這段代碼在IE中毫無問題,問題出在FF。原因是NOTfloatC并非float標簽,必須將float標簽閉合。
所以得在<div id="floatB"></div>后邊加清除浮動<div class="clear"></div>
定義如下.clear{clear:both;}
2. 注意margin加倍的問題
現在DIV+CSS布局里用的最多的要數margin和padding了(為了兼容性都盡量少用),設置為float浮動后的div在ie下設置的margin會加倍,所以要在這個div里面加上display:inline;
示例:<div id="FloatA"></div>
相應的css為
#FloatA{
float:left;
margin:5px;/*IE下理解為10px*/
display:inline;/*IE下再理解為5px*/
}
說了這么多,歸根結底還是CSS的解釋問題,所以在以后制作DIV+CSS頁面時要遵循W3C標準,聲明doctype,讓瀏覽器按strict mode模式解析CSS,時刻注意IE6、IE7及火狐瀏覽器的差異,就會避免很多兼容性問題,做出更好的作品來
烏魯木齊網站制作、烏魯木齊網站推廣、烏魯木齊網站排名、網站開發、新疆網站建設、新疆網站推廣、新疆網站排名找遠璨網絡,誠信合作共贏的態度,為你提供更多的網站建設服務!咨詢電話:0991-4549085
中文字幕一区二区三区四区不卡| 成人一二三区视频| 久久精品国产精品亚洲精品| 欧美中文字幕久久| 亚洲欧美日韩久久精品| 欧美刺激午夜性久久久久久久| 日韩影视精彩在线| 久久久综合激的五月天| 欧美视频在线不卡| www.性欧美| 国产91高潮流白浆在线麻豆| 日本不卡123| 亚洲国产乱码最新视频| 国产精品对白交换视频| 久久精品夜色噜噜亚洲a∨ | 国产精品免费视频网站| 成人在线综合网| 亚洲香肠在线观看| 久久久久久一二三区| 欧美久久一二区| 色综合色综合色综合 | 欧美日韩一区小说| 亚洲欧美精品午睡沙发| 欧美一区二区在线不卡| 97成人超碰视| 看电影不卡的网站| 国产精品久久久久久久久免费相片 | 日本乱人伦aⅴ精品| 久久久久97国产精华液好用吗| 亚洲不卡av一区二区三区| 粉嫩嫩av羞羞动漫久久久| 日韩你懂的在线播放| 麻豆精品视频在线| 在线综合视频播放| 日韩精品电影在线| 精品日韩一区二区三区| 日韩黄色免费电影| 日韩一二三四区| 国产精品一二三区在线| 国产精品人成在线观看免费| 不卡的av在线| 亚洲一区二区五区| 欧美成人综合网站| 粉嫩av一区二区三区| 国产精品私人自拍| 色综合天天综合色综合av| 亚洲综合色视频| 欧美电影免费观看高清完整版在线 | 不卡视频一二三四| 亚洲r级在线视频| 精品国产a毛片| 不卡的电视剧免费网站有什么| 一区二区三区在线免费观看| 欧美曰成人黄网| 久久99国产精品尤物| 中文字幕亚洲在| 亚洲图片欧美激情| 91福利社在线观看| 国产精品一线二线三线精华| 一区二区在线观看视频在线观看| 欧美一区二区三区四区高清| 狠狠色狠狠色综合系列| 亚洲欧美激情视频在线观看一区二区三区 | 色狠狠一区二区| 国产成人av电影| 国内精品第一页| 丝袜美腿亚洲色图| 中文字幕免费在线观看视频一区| 欧美丝袜丝交足nylons图片| a在线欧美一区| 国产91在线|亚洲| 顶级嫩模精品视频在线看| 蜜桃av噜噜一区| 日产欧产美韩系列久久99| 亚洲国产成人va在线观看天堂| 国产精品丝袜在线| 日韩久久一区二区| 亚洲欧美偷拍另类a∨色屁股| 国产欧美日韩精品a在线观看| 日韩女优电影在线观看| 日韩一级免费一区| 久久综合给合久久狠狠狠97色69| 欧美一级久久久| 日韩视频一区在线观看| 精品国产不卡一区二区三区| 欧美videos中文字幕| 久久久久久久久99精品| 中文字幕不卡在线观看| 亚洲精品乱码久久久久久日本蜜臀| 一区二区理论电影在线观看| 性做久久久久久久久| 亚洲高清一区二区三区| 日本中文一区二区三区| 国内久久婷婷综合| 成a人片国产精品| 欧美性做爰猛烈叫床潮| 久久奇米777| 肉色丝袜一区二区| 国产一区二区三区在线观看免费| 懂色av一区二区夜夜嗨| 91精品国产综合久久婷婷香蕉| 2019国产精品| 免费观看久久久4p| 欧美色视频在线观看| 国产精品午夜久久| 国产一区二区在线观看免费| 日本久久一区二区| 国产精品热久久久久夜色精品三区| 轻轻草成人在线| 欧美巨大另类极品videosbest | 国产精品资源网| 日韩一区二区三区电影| 亚洲国产精品天堂| 在线一区二区三区| 一区二区三区在线视频观看 | 欧美视频在线观看一区二区| 中文字幕一区二区三区不卡在线 | 欧美在线一二三| 亚洲色图在线播放| 99久久综合色| 日韩成人午夜精品| 欧美欧美欧美欧美| 亚洲午夜影视影院在线观看| 91网站视频在线观看| 日韩理论片网站| 欧美性大战久久久久久久蜜臀| 亚洲在线观看免费| 91精品国模一区二区三区| 久久99精品国产.久久久久| 国产日产欧美精品一区二区三区| 91片在线免费观看| 免费成人结看片| 亚洲婷婷在线视频| 日韩欧美另类在线| 91婷婷韩国欧美一区二区| 青青草97国产精品免费观看| 国产精品色在线观看| 欧美日韩免费高清一区色橹橹 | 欧洲精品一区二区| 国产一区在线精品| 亚洲蜜桃精久久久久久久| 欧美色综合久久| 91片黄在线观看| 国产一区二区不卡| 精品国产三级电影在线观看| 日韩福利视频导航| 色狠狠综合天天综合综合| 成人国产精品免费网站| 色婷婷久久久亚洲一区二区三区 | 亚洲一区免费在线观看| 日韩av一区二区在线影视| 成人久久18免费网站麻豆| 欧美一级艳片视频免费观看| 4438x亚洲最大成人网| 91精品国产一区二区三区香蕉| 91精品国产福利| 精品福利一区二区三区| 国产无遮挡一区二区三区毛片日本| 欧美情侣在线播放| 91超碰这里只有精品国产| 欧美午夜精品一区二区蜜桃| 欧美在线综合视频| 91麻豆精品国产91久久久久久久久 | 亚洲国产中文字幕在线视频综合| 国产日产欧美一区二区三区| 国产三级精品视频| 国产人妖乱国产精品人妖| 国产网站一区二区三区| 国产精品视频观看| 日韩vs国产vs欧美| 久久精品国产在热久久| 成人一区二区在线观看| 欧美性淫爽ww久久久久无| 色婷婷精品大在线视频 | 国产日韩欧美精品一区| 亚洲欧美综合网| 蜜臀91精品一区二区三区| 91在线云播放| 久久色成人在线| 亚洲电影欧美电影有声小说| 亚洲一区二区三区激情| av一区二区久久| 国产精品女主播av| 国产一区二区三区精品欧美日韩一区二区三区| www.久久精品| 91丨porny丨首页| 国产婷婷一区二区| 国产精品自拍av| 欧美—级在线免费片| 成人丝袜高跟foot| 欧美精品一区二区三区蜜臀| 五月天网站亚洲| 欧美精品丝袜中出| 日韩精品欧美成人高清一区二区| 91麻豆免费在线观看| 国产精品久久久久永久免费观看| 极品少妇xxxx精品少妇偷拍| 久久精品一区二区三区四区| 狠狠色综合播放一区二区| 久久色成人在线|