您的位置:首页 > Web前端 > CSS

Css Hack(ie6-9,firefox,chrome,opera,safari)

2016-10-18 20:15 357 查看
为了适应不同浏览器不同的版本(版本主要就ie来说),ie这朵奇葩现在我们要兼容6-9,它的10也快出来了。。。在ie下我们可以写条件注释来区分ie和其他浏览器,以及ie的版本,这些请大家自行google。这篇文章主要讨论的是css hack。下面废话补多说了,直接上代码

DOCTYPE html>  
<</SPAN>html>  
<</SPAN>head>  

    <</SPAN>title>Css Hack</</SPAN>title>  

    <</SPAN>style>  

    #test   

    {   

        width:300px;   

        height:300px;   

          

        background-color:blue;      

        background-color:red\9;      

        background-color:yellow\0;    

        +background-color:pink;        

        _background-color:orange;       

    }  

    :root #test { background-color:purple\9; }  

    @media all and (min-width:0px){ #test {background-color:black\0;} }  

    @media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }  

    </</SPAN>style>  
</</SPAN>head>  
<</SPAN>body>  

    <</SPAN>div id="test">test</</SPAN>div>  
</</SPAN>body>  
</</SPAN>html> 

上面这段代码大家可以直接copy出来,保存成html在各浏览器试试。下面我来分析下:
    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的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息