史上最全的css hack(ie6-9,firefox,chrome,opera,safari)

      在这个浏览器百花争鸣的时代,做为前端开发的咱们为了咱们漂亮的设计能适应各个浏览器可为煞费苦心,主要体如今javascript和css上面。javascript我此次就不谈了,先说说css。
      为了适应不一样浏览器不一样的版本(版本主要就ie来讲),ie这朵奇葩如今咱们要兼容6-9,它的10也快出来了。。。在ie下咱们能够写条件注释来区分 ie和其余浏览器,以及ie的版本,这些请你们自行google。这篇文章主要讨论的是css hack。下面废话补多说了,直接上代码

<!DOCTYPE html>  
<html>  
<head>  
    <title>Css Hack</title>  
    <style>  
    #test   
    {   
        width:300px;   
        height:300px;   
          
        background-color:blue;      /*firefox*/
        background-color:red\9;      /*all ie*/
        background-color:yellow\0;    /*ie8*/
        +background-color:pink;        /*ie7*/
        _background-color:orange;       /*ie6*/
    }  
    :root #test { background-color:purple\9; }  /*ie9*/
    @media all and (min-width:0px){ #test {background-color:black\0;} }  /*opera*/
    @media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }  /*chrome and safari*/
    </style>  
</head>  
<body>  
    <div id="test">test</div>  
</body>  
</html>

上面这段代码你们能够直接copy出来,保存成html在各浏览器试试。下面我来分析下:javascript

background-color:blue; 各个浏览器都认识,这里给firefox用;
    background-color:red\9;\9全部的ie浏览器可识别;
    background-color:yellow\0; \0 是留给ie8的,但笔者测试,发现最新版opera也认识,汗。。。不过且慢,后面自有hack写了给opera认的,因此,\0咱们就认为是给ie8留的;
    +background-color:pink; + ie7定了;
    _background-color:orange; _专门留给神奇的ie6;
    :root #test { background-color:purple\9; } :root是给ie9的,网上流传了个版本是  :root #test { background-color:purple\0;},呃。。。这个。。。,新版opera也认识,因此经笔者反复验证最终ie9特有的为:root 选择符 {属性\9;}
    @media all and (min-width:0px){ #test {background-color:black\0;} } 这个是总是跟ie抢着认\0的神奇的opera,必须加个\0,否则firefox,chrome,safari也都认识。。。
    @media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }最后这个是浏览器新贵chrome和safari的。


    好了就这么多了,特别注意以上顺序是不能够改变的。css hack虽然能够解决个浏览器之间css显示的差别问题,可是毕竟不符合W3C规范,咱们平时写css最好是按照标准来,这样对咱们之后维护也是大有好处的,实在不行再用。

    若是给位看官有更好的css hack写法或者本文有不妥之处,欢迎留言,第一次写文章,请轻砸。
相关文章
相关标签/搜索