• css hack(1)


    为 了适应不同浏览器不同的版本(版本主要就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-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在各浏览器试试。下面我来分析下:

        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-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最好是按照标准来,这样对我们以后维护也是大有好处的,实在不行再用。
  • 相关阅读:
    P4839 P哥的桶 题解(线段树维护线性基)
    线性基入门
    Lowest Common Ancestor 题解(lca+思维)
    B
    java string对象的简单方法
    AtCoder Grand Contest 016 D
    FFT
    回文自动机(BZOJ2565)
    二维RMQ
    AC自动机(BZOJ1030)
  • 原文地址:https://www.cnblogs.com/iloveyoucc/p/2688670.html
Copyright © 2020-2023  润新知