關(guān)于瀏覽器的兼容性問題,我寫過一篇小文章,《回答讀者提問(12)——關(guān)于CSS在不同瀏覽器的調(diào)試經(jīng)驗》。今天在就這個問題,談一些制作中的技巧。
首先,關(guān)于CSS hack的方法網(wǎng)上有很多介紹,種類繁多,初學(xué)者常常感到很困惑。這類的CSS hack的方法,有的是針對某一個非常特殊的情況的方法,有的則是相對于比較通用的一些方法。
對于后者我們在平常的學(xué)習(xí)工作中,可以多留心收集一些,前者則不需要太關(guān)注,只是遇到的時候到網(wǎng)上搜索一下,尋找解決方法即可。
這里舉一個比較通用的hack方法,比如對于CSS中的某一個屬性,我們希望針對不同的瀏覽器,設(shè)置不同的值。例如,某一個div,我們希望在Firefox中寬度為50像素,在IE中寬度為60像素。那么怎么實現(xiàn)呢?請看如下代碼:
1 2 3 4 |
#demo div{ width:50px; /* FireFox 有效 */ +width:60px; /* IE 有效 */ } |
在上面的代碼中, 第2行的width:50px這是普通的樣式,下一行中,在width屬性前面加一個加號,這條樣式在Firefox中被認為無效,但是在IE中這個加號會被忽略掉,因此仍然被理解為width屬性,從而覆蓋上一條的設(shè)置,這樣就可以區(qū)分Firefox瀏覽器和IE瀏覽器了。
那么如果希望進一步區(qū)分IE 6和IE 7呢?請看如下代碼:
1 2 3 4 5 |
#demo div{ width:50px; /* FireFox 有效 */ +width:60px; /* IE 7 有效 */ _width:70px; /* IE 6 有效 */ } |
上面代碼就可以實現(xiàn)對三種瀏覽器的區(qū)分了。在IE7中,屬性前加一個加號,這個加號會被忽略,而如果在屬性前加一個下劃線這整條樣式會被忽略,從而實現(xiàn)了對這三種主流瀏覽器的區(qū)分。
到這里,我們自然會想到,什么情況下會用的這種方法來區(qū)分瀏覽器呢?我們要制作的頁面,通常會有兩種情況,一種是徹底從頭開始做,另一種是基于一個已經(jīng)存在的網(wǎng)頁進行修改或者修補。
對于第一種情況來說,我們對網(wǎng)頁的每一個細節(jié)都十分清楚,因此并不經(jīng)常遇到非常Firefox和IE的兼容性問題,即使遇到了,一般也可以找到其他方法解決。而對于第二種情況來說,則復(fù)雜的多了,因為一個網(wǎng)頁可能非常復(fù)雜,層疊關(guān)系也很復(fù)雜,對于后接手的人,很難搞清楚某一個的屬性上面有多少層設(shè)置會對他產(chǎn)生影響,因此往往只能采用“貼膏藥”的方式進行修補。
比如說,如下的一個頁面的最終效果,在制作圓角框的時候,在IE中,圓角對整齊之后,在firefox中卻出現(xiàn)如圖所示的錯位,而如果按照Firefox調(diào)整好,在IE中又會出現(xiàn)錯位。

而頁面的內(nèi)容層層嵌套,在并不知道細節(jié)的情況下,很難找到問題的根源。因此這里使用修補的方法就很方便(盡管不是最優(yōu)雅完善的方法),例如對于控制圓角圖像位置的屬性使用上面的方法,分別控制即可。
總上所述,對任何屬性都可以使用加號或者下劃線方法,來實現(xiàn)針對不同瀏覽器的各自設(shè)置。當然,最后還是要指出,任何hack方法都要慎重使用,最好還是能夠按照標準、優(yōu)雅的CSS來進行設(shè)計,這樣的代碼可讀性、維護性都要好很多,也是我們追求的目標。
5,959