DIV+CSS建站對瀏覽器的相容性問題和注意事項

來源:互聯網
上載者:User

使用DIV+CSS構架好處不少,但也確實存在一些問題,現在讓網頁設計師最頭疼的事莫過於DIV+CSS對瀏覽器的相容性了,可能你用慣了IE6,做出來的東西沒感覺到有多大異常,但是把同樣的東西放到IE7裡去看的話,就會發現很多問題,如果放到Firefox瀏覽器裡去看,結果更不盡人意。

    一個頁面從製作的開始就決定了他要使用的瀏覽器解析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及FFFirefox瀏覽器的區別和相容方法:
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和Firefox對'width'定義的不同:
     Firefox中:容器占的寬度=內容寬度+padding寬度+border寬度;
     IE中:內容寬度=您定義的容器寬度(Internet Explorer 'width')-padding寬度-border寬度
     (Internet Explorer 'width'則是指整個容器的寬度,包括內容,padding ,border)

6. css布局的置中問題:FFFirefox裡設定margin-left, margin-right 為 auto 時已經置中, IE則設定body {TEXT-ALIGN: center;} 才行
7. FFFirefox設定padding後, div會增加height和width, 但IE不會, 故需要用 !important 多設一個height和width
8. 在mozilla firefox和IE中的BOX模型解釋不一致導致相差2px解決方案:div{margin:30px!important;margin:28px;}
9. ul標籤在FFFirefox中預設是有padding值的,而在IE中只有margin有值所以先定義ul{margin:0;padding:0;}
10.終結解決方案:
    (1)!important:FFFirefox和IE7對於"!important"會自動優先解析,IE6則忽略,可用!important為FFFirefox和IE7 單獨設定樣式,不影響IE6的顯示,值得注意的是,一定要將xxxx !important 這句放置在另一句之上。
       樣本:div{margin:30px!important;margin:15px;} //在FFFirefox和IE7中margin:30px,在IE6中margin:15px;
    (2)由於FFFirefox和IE7都支援"!important",而二者之間也存在差異,所以有時也會出現一些小問題,針對IE7可以使用使用"*+html",
       樣本:#example { color: #333; } /* FFFirefox下字型顏色顯示為#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及Firefox瀏覽器的差異,就會避免很多相容性問題,做出更好的作品來

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.