乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      回答讀者提問(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中被認為無效,但是在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)錯位。

      CSS圓角錯位

       

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

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

      5,959

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

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多