DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> CSS入門知識 >> CSS詳解 >> DIV+CSS設計IE6、IE7、Firefox兼容性(1)
DIV+CSS設計IE6、IE7、Firefox兼容性(1)
編輯:CSS詳解     

你對DIV+CSS設計IE6、IE7、Firefox兼容性問題是否比較熟悉,這裡和大家分享一下,對完全使用DIV+CSS設計的網頁,就應該更注意IE6、IE7、Firefox對CSS樣式的兼容。

DIV+CSS設計IE6、IE7、Firefox兼容性

DIV+CSS網頁布局這是一種趨勢,我也開始順應這股趨勢了,不過在使用DIV+CSS網站設計的時候,應該注意css樣式兼容不同浏覽器問題,特別是對完全使用DIV+CSS設計的網頁,就應該更注意IE6、IE7、Firefox對CSS樣式的兼容,不然,你的網頁可能亂的一塌糊塗!我經常被這些東西整的焦頭爛額,於是乎在網上找了些資料,加上自己的理解和這些日子的經驗,整理了一些資料,其中有一些我還沒用到的和還不能理解的,就直接從別的地方給粘了過來,不知道有沒有錯誤,等我以後用到的時候慢慢改吧,希望對大家有點幫助!

什麼是浏覽器兼容:當我們使用不同的浏覽器(FirefoxIE7IE6)訪問同一個網站,或者頁面的時候,會出現一些不兼容的問題,在這種浏覽器下顯示正常,在另一種下就亂了,我們在編寫CSS的時候會很惱火,剛修復了這個浏覽器的問題,結果另外一個浏覽器卻出了新問題。好吧,我服了行吧,那我就利用你們的不兼容各寫一段CSS,讓他們各執行各的,這下總該你沒脾氣了吧,呵呵。

一、!important(功能有限)

隨著IE7對!important的支持,!important方法現在只針對IE6的兼容.(注意寫法.記得該聲明位置需要提前.)
例如:

  1. #example{
  2. width:100px!important;/*IE7+Firefox*/
  3. width:200px;/*IE6*/
  4. }

二、CSSHACK的方法

首先需要知道的是:

所有浏覽器通用height:100px;
IE6專用_height:100px;
IE7專用*+height:100px;
IE6、IE7共用*height:100px;
IE7、Firefox共用height:100px!important;

例如:

  1. #example{height:100px;}/*Firefox*/
  2. *Html#example{height:200px;}/*IE6*/
  3. *+Html#example{height:300px;}/*IE7*/

下面的這種方法比較簡單

舉幾個例子:

1、IE6-IE7+Firefox

  1. #example{
  2. height:100px;/*Firefox+IE7*/
  3. _height:200px;/*IE6*/
  4. }
  5. 其實這個用上面說的第一種方法也可以
  6. #example{
  7. height:100px!important;/*Firefox+IE7*/
  8. height:200px;/*IE6*/
  9. }

2、IE6+IE7-Firefox

  1. #example{
  2. height:100px;/*Firefox*/
  3. *height:200px;/*IE6+IE7*/
  4. }

3、IE6+Firefox-IE7

  1. #example{
  2. height:100px;/*IE6+Firefox*/
  3. *+height:200px;/*IE7*/
  4. }

4、IE6IE7Firefox各不相同

  1. #example{
  2. height:100px;/*Firefox*/
  3. _height:200px;/*IE6*/
  4. *+height:300px;/*IE7*/
  5. }
  6. 或:
  7. #example{
  8. height:100px;/*Firefox*/
  9. *height:300px;/*IE7*/
  10. _height:200px;/*IE6*/
  11. }

需要注意的是,代碼的順序一定不能顛倒了,要不又前功盡棄了。因為浏覽器在解釋程序的時候,如果重名的話,會用後面的覆蓋前面的,就象給變量賦值一個道理,所以我們把通用的放前面,越專用的越放後面。
解釋一下4的代碼:

讀代碼的時候,第一行height:100px;大家都通用,IE6IE7Firefox都顯示100px
到了第二行*height:300px;Firefox不認識這個屬性,IE6IE7都認,所以Firefox還顯示100px,而IE6IE7把第一行得到的height屬性給覆蓋了,都顯示300px

到了第三行_height:200px;只有IE6認識,所以IE6就又覆蓋了在第二行得到的height,最終顯示200px
這樣,三個浏覽器都有自己的height屬性了,各玩各的去吧

這樣說要是你還不明白,要麼你去撞牆,要麼我去!不過還是你去比較好。

哦,差點忘了說了:
*+html對IE7的兼容必須保證Html頂部有如下聲明:

  1. "http://www.w3.org/TR/Html4/loose.dtd">
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved