日期:2014-05-17  浏览次数:20681 次

CSS区分各浏览器Hack
CSS区分各浏览器Hack

浏览量:25 | 分类:前端开发HTML5/JS | 发布日期:2011-12-06


虽然我不提倡用Css Hack,
但是有时候不得不用Css Hack处理一些比较头疼的样式
以下是区分IE6,IE7,IE8,IE9,Firefox,Chrome,Opera,Safari的Hack写法
也是目前最全的CssHack


#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*/<br>
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最好是按照标准来,这样对我们以后维护也是大有好处的,实在不行再用。


http://www.nonb.cn/blog/css-all-hack.html