[13年迁移]firefox and chrome css compatible

firefox:
a标签需要指定display:block;,才可以设置长宽,不然无效

chrome:

common:
这个最全,还要加一个
 @-moz-document url-prefix(){
 
 }火狐专有

还要加一个!important的正确理解,其他浏览器参考w3c,在ie6下不能覆盖前面声明的css类,但是可以覆盖内联css(就是元素style里的),是可以用的

ie系列还可以用*号貌似

    上面这段代码大家可以直接copy出来,保存成html在各浏览器试试。下面我来分析下:

    各个浏览器都认识,这里给firefox用;
    \9所有的ie浏览器可识别;
    \0 是留给ie8的,但笔者测试,发现最新版opera也认识,汗。。。不过且慢,后面自有hack写了给opera认的,所以,\0我们就认为是给ie8留的;
    + + ie7定了;
    _ _专门留给神奇的ie6;
    :root #test { } :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 {} }最后这个是浏览器新贵chrome和safari的。
 
    好了就这么多了,特别注意以上顺序是不可以改变的。css hack虽然可以解决个浏览器之间css显示的差异问题,但是毕竟不符合W3C规范,我们平时写css最好是按照标准来,这样对我们以后维护也是大有好处的,实在不行再用。


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。