zoukankan      html  css  js  c++  java
  • css hack

    1、常见的特殊符号的应用:

    IE6:

    _selector{property:value;}

    selector{property:value;property:value !important;} //IE6 不支持同一选择符中的 !important

    IE7:

    +selector{property:value;}

    IE8:

    selector{property:value;}

    IE6 & IE7:

    *selector{property:value;}

    IE6 & IE7 & IE8:

    selector{property:value9;}

    总结起来,如下:

    其中,S表示Standards Mode即标准模式,Q表示Quirks Mode,即兼容模式。

    (了解更多Quirks模式、Strict(Standars)模式?)

    hack 示例 IE6(S) IE6(Q) IE7(S) IE7(Q) IE8(S) IE8(Q)
    * *color Yes Yes Yes Yes No Yes
    + +color Yes Yes Yes Yes No Yes
    - -color Yes Yes No No No No
    _ _color Yes Yes No Yes No Yes
    # #color Yes Yes Yes Yes No Yes
    color No No No No Yes No
    9 color9 Yes Yes Yes Yes Yes Yes
    !important color:blue !important;
    color:green;
    No No Yes No Yes No

    2、条件注释语句(<!--[if IE]> <![endif]-->)

    所有的IE可识别 

    仅IE6可识别 

    IE6以及IE6以上版本可识别 

    IE7以下版本可识别 


    lt 表示less than 当前条件版本以下的版本,不包含当前版本。

    gte 表示greeter than or equal 当前版本以上版本,并包含当前版本。

    lte 表示less than or equal 当前版本以下版本,并包含当前版本。

    3、meta声明

    由于IE8 可能会将页面按照 IE7 模式进行渲染,针对 多版本IE的现状,通常会采用设置 X-UA-Compatible HTTP 头的方式将页面在IE中采用统一的渲染模式。

     //标准 IE7 模式
     //兼容 IE7 模式
    //标准 IE 模式

    4、其他(/***/注释法)

    网上也流传着这样一种ie hack方法

    .color1{ color:#F00; color/***/:#00F /***/}/*IE6,IE7,IE8,FF,OP,SA识别*/
    .color2{ color:#F00; color /***/:#00F /*9**/}/*IE7,IE8,FF,OP,SA识别*/
    .color3{ color:#F00; color/***/:#00F 9}/*IE6,IE7,IE8识别*/
    .color4{ color:#F00; color /***/:#00F9}/*IE7,IE8识别*//*“color”和“/***/”之间有个空格*/

    分析下:
    各个浏览器都认识,这里给firefox用;
    background-color:red9;9所有的ie浏览器可识别;
    background-color:yellow; 是留给ie8的,但笔者测试,发现最新版opera也认识,汗。。。不过且慢,后面自有hack写了给opera认的,所以,我们就认为是给ie8留的;
    +background-color:pink; + ie7定了;
    _background-color:orange; _专门留给神奇的ie6;
    :root #test { background-color:purple9; } :root是给ie9的,网上流传了个版本是 :root #test { background-color:purple;},呃。。。这个。。。,新版opera也认识,所以经笔者反复验证最终ie9特有的为:root 选择符 {属性9;}
    @media all and (min-0px){ #test {background-color:black;} } 这个是老是跟ie抢着认的神奇的opera,必须加个,不然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写法: 

    区别IE6与FF: 
    background:orange;*background:blue; 

    区别IE6与IE7: 
    background:green !important;background:blue; 

    区别IE7与FF: 
    background:orange; *background:green; 

    区别FF,IE7,IE6: 
    background:orange;*background:green !important;*background:blue; 

    注:IE都能识别*;标准浏览器(如FF)不能识别*;
    IE6能识别*,但不能识别 !important, 
    IE7能识别*,也能识别!important; 
    FF不能识别*,但能识别!important;

      IE6 IE7 FF
    * ×
    !important ×



    ------------------------------------------------------ 
    另外再补充一个,下划线"_", 
    IE6支持下划线,IE7和firefox均不支持下划线。

      IE6 IE7 FF
    * ×
    !important ×
    _ × ×

  • 相关阅读:
    js 点击列表li,获得当前li的id
    PHP松散比较与严格比较的区别详解
    电赛总结(二)——AD芯片总结之AD7705
    C++Premer Plus学习(五)——函数探幽
    FPGA学习
    AD7715
    电赛初探(二)——语音采集回放系统
    MATLAB信号与系统分析(五)——连续时间信号的频谱分析
    MATLAB信号与系统分析(四)——离散信号与系统的复频域分析及MATLAB实现
    MATLAB信号与系统分析(三)——连续信号与系统的复频域分析及MATLAB实现
  • 原文地址:https://www.cnblogs.com/zhengyan/p/4922824.html
Copyright © 2011-2022 走看看