小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

回答讀者提問(19)——再談瀏覽器的兼容性 - CSS,Javascript,jQuery...

 櫻楓飄雪 2011-04-21

回答讀者提問(19)——再談瀏覽器的兼容性

關(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中被認(rèn)為無效,但是在IE中這個加號會被忽略掉,因此仍然被理解為width屬性,從而覆蓋上一條的設(shè)置,這樣就可以區(qū)分Firefox瀏覽器和IE瀏覽器了。

那么如果希望進(jìn)一步區(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)頁進(jìn)行修改或者修補(bǔ)。

對于第一種情況來說,我們對網(wǎng)頁的每一個細(xì)節(jié)都十分清楚,因此并不經(jīng)常遇到非常Firefox和IE的兼容性問題,即使遇到了,一般也可以找到其他方法解決。而對于第二種情況來說,則復(fù)雜的多了,因為一個網(wǎng)頁可能非常復(fù)雜,層疊關(guān)系也很復(fù)雜,對于后接手的人,很難搞清楚某一個的屬性上面有多少層設(shè)置會對他產(chǎn)生影響,因此往往只能采用“貼膏藥”的方式進(jìn)行修補(bǔ)。

比如說,如下的一個頁面的最終效果,在制作圓角框的時候,在IE中,圓角對整齊之后,在firefox中卻出現(xiàn)如圖所示的錯位,而如果按照Firefox調(diào)整好,在IE中又會出現(xiàn)錯位。

CSS圓角錯位

 

而頁面的內(nèi)容層層嵌套,在并不知道細(xì)節(jié)的情況下,很難找到問題的根源。因此這里使用修補(bǔ)的方法就很方便(盡管不是最優(yōu)雅完善的方法),例如對于控制圓角圖像位置的屬性使用上面的方法,分別控制即可。

總上所述,對任何屬性都可以使用加號或者下劃線方法,來實現(xiàn)針對不同瀏覽器的各自設(shè)置。當(dāng)然,最后還是要指出,任何hack方法都要慎重使用,最好還是能夠按照標(biāo)準(zhǔn)、優(yōu)雅的CSS來進(jìn)行設(shè)計,這樣的代碼可讀性、維護(hù)性都要好很多,也是我們追求的目標(biāo)。

5,959

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多