亚洲天堂一级片-亚洲天堂三区-亚洲天堂久久精品成人-亚洲天堂毛片-久久国产欧美日韩高清专区-久久国产欧美日韩精品免费

北大青鳥課程講解之:css hack

北京北大青鳥學校學術部老師講解:CSS hack由于不同的瀏覽器,比如Internet Explorer 6,Internet Explorer 7,Mozilla Firefox等,對CSS的解析認識不一樣,因此會導致生成的頁面效果不一樣,得不到我們所需要的頁面效果。 這個時候我們就需要針對不同的瀏覽器去寫不同的CSS,讓它能夠同時兼容不同的瀏覽器,能在不同的瀏覽器中也能得到我們想要的頁面效果。這個針對不同的瀏覽器寫不同的CSS code的過程,就叫CSS hack!

北大青鳥學校丁老師介紹:編輯本段CSS Hack的原理是什么
由于不同的瀏覽器對CSS的支持及解析結果不一樣,還由于CSS中的優先級的關系。我們就可以根據這個來針對不同的瀏覽器來寫不同的CSS。

CSS Hack大致有3種表現形式,CSS類內部Hack、選擇器Hack以及HTML頭部引用(if IE)Hack,CSS Hack主要針對IE瀏覽器。

類內部Hack:比如 IE6能識別下劃線"_"和星號" * ",IE7能識別星號" * ",但不能識別下劃線"_",而firefox兩個都不能認識。等等

選擇器Hack:比如 IE6能識別*html .class{},IE7能識別*+html .class{}或者*:first-child+html .class{}。等等

HTML頭部引用(if IE)Hack:針對所有IE:<!--[if IE]><!--您的代碼--><![endif]-->,針對IE6及以下版本:<!--[if lt IE 7]><!--您的代碼--><![endif]-->,這類Hack不僅對CSS生效,對寫在判斷語句里面的所有代碼都會生效。

書寫順序,一般是將識別能力強的瀏覽器的CSS寫在后面。下面如何寫里面說得更詳細些。(北大青鳥課程

 

北大青鳥學校丁老師介紹:如何寫CSS Hack

比如要分辨IE6和firefox兩種瀏覽器,可以這樣寫:

  <style>

  div{

  background:green; /* for firefox */

  *background:red; /* for IE6 */

  }

  </style>

我在IE6中看到是紅色的,在firefox中看到是綠色的。(北大青鳥課程)

北大青鳥學校解釋一下:

上面的css在firefox中,它是認識不了后面的那個帶星號的東東是什么的,于是將它過濾掉,不予理睬,解析得到的結果是:div{background:green},于是理所當然這個div的背景是綠色的。

在IE6中呢,它兩個background都能識別出來,它解析得到的結果是:div{background:green;background:red;},于是根據優先級別,處在后面的red的優先級高,于是當然這個div的背景顏色就是紅色的了。(北大青鳥課程)

  CSS hack:區分IE6,IE7,firefox

  區別不同瀏覽器,CSS hack寫法:

  區別IE6與FF:

  background:orange;*background:blue;

  區別IE6與IE7:

  background:green !important;background:blue;

  區別IE7與FF:

  background:orange; *background:green;

  區別FF,IE7,IE6:

  background:orange;*background:green;_background:blue;

  background:orange;*background:green !important;*background:blue;

  注:IE都能識別*;標準瀏覽器(如FF)不能識別*;

  IE6能識別*,某些情況下不能識別 !important,(北大青鳥課程)

  -----------------------------------------------------------------------------------------------

  IE6支持重定義中的!important,例如:

  .yuanxin {color:#e00!important;}

  .yuanxin {color:#000;}

  你將會發現定義了樣式class="yuanxin"時,在IE下,字體顯示為紅色(#e00)。

  但不支持同一定義中的!important。例如:

  .yuanxin {color:#e00!important;color:#000}

  此時在IE6下不支持,你將會發現定義了樣式class="yuanxin"時,字體顯示為黑色(#000)。

  不包括如下這種形式的同一定義中的!important。

  #pageOver{height:expression(document.documentElement.offsetHeight)!important;

  height:100%;}此種形式的定義,IE6中是可以解釋到important的。

  -----------------------------------------------------------------------------------------------

  IE7能識別*,也能識別!important;

  FF不能識別*,但能識別!important;

                          IE6                 IE7                 FF

  *                         √                 √                 ×

  !important         ×                 √                √

瀏覽器優先級別:FF<IE7<IE6,CSS hack書寫順序一般為FF IE7 IE6

 

  以: " #demo {width:100px;} "為例;(北大青鳥課程)

  #demo {width:100px;} /*被FIREFOX,IE6,IE7執行.*/

  * html #demo {width:120px;} /*會被IE6執行,之前的定義會被后來的覆蓋,所以#demo的寬度在IE6就為120px; */

  *+html #demo {width:130px;} /*會被IE7執行*/

  ---------------

  所以最后,#demo的寬度在三個瀏覽器的解釋為:

  FIREFOX:100px;

  ie6:120px;

  ie7:130px;

  IE8 最新css hack:

  "\9" 例:"border:1px \9;".這里的"\9"可以區別所有IE和FireFox.

   "\0" IE8識別,IE6、IE7不能.

  "*" IE6、IE7可以識別.IE8、FireFox不能.

  "_" IE6可以識別"_",IE7、IE8、FireFox不能.(北大青鳥課程)

以上內容由北京北大青鳥學校學術部提供

北大青鳥網上報名
北大青鳥招生簡章
主站蜘蛛池模板: 国产三级国产精品国产普男人 | 国内精品一区二区三区最新 | 欧美日韩国产免费一区二区三区 | 亚洲一区二区三区福利在线 | 色综合久久久高清综合久久久 | 国产精品亚洲玖玖玖在线靠爱 | 国产一级a毛片高清 | 一级毛片私人影院免费 | 亚洲一区二区三区在线视频 | 午夜国产精品久久久久 | 6一12呦女精品 | 欧美国产日本精品一区二区三区 | 一级一级特黄女人精品毛片 | 91视频国产91久久久 | 亚洲欧美精品一区天堂久久 | 日韩精品欧美激情国产一区 | 久章草视频 | 外国三级毛片 | 成人性视频在线 | 一区二区成人国产精品 | 九九黄色影院 | 日韩精品中文字幕在线 | 国产国产成人精品久久 | 最近中文字幕在线 | 中文 | 91成人免费观看在线观看 | 成人全黄三级视频在线观看 | 国产在线欧美日韩精品一区二区 | 国产精品一区二区三区四区五区 | 做爰成人五级在线视频| 久久久美女视频 | 国产精品2020| 香港三级日本三级三级人妇 | 日本又黄又爽又免费 | 日本综合欧美一区二区三区 | 91啦丨国产丨 | 亚洲国产精品国产自在在线 | 亚洲天堂2017| 欧美成人精品高清在线观看 | 最新亚洲精品国自产在线 | 手机看片1024欧美日韩你懂的 | 9191久久久久视频 |