设为首页  |  SEO论坛  |  CSS在线手册  |  收藏本站  |  
您的位置:seo俱乐部 >> CSS教程 >> css hack(css兼容详解)

    css hack(css兼容详解)

  •         2007-9-24 13:21:48    点击率:
  • css hack(css兼容详解)

    IE6/IE7对FF
    1.*+html 与 *html 是IE特有的标签, firefox 暂不支持.
    而*+html 又为 IE7特有标签.

    <style>
    #wrapper
    {
    #wrapper { width: 120px; } /* FireFox */
    *html #wrapper { width: 80px;} /* ie6 fixed */
    *+html #wrapper { width: 60px;} /* ie7 fixed, 注意顺序 */
    }
    </style>
    2.表达方式:+property:value

    测试环境:IE5,IE6 ,IE7,FF1.5,FF2.0,Opera 9,Safari 2
    测试结果:
    IE5,IE6 ,IE7浏览器识别;
    FF2.0,Opera 9,Safari 2浏览器不识别。
    结论:我们可以用"+"来实现只有IE识别的CSS Hack。
    比如我们要实现在IE中500px的宽度,而在其他浏览器480px的宽度,就可以通过"+" Hack来完成,如下:
    #hack {
    width:500px;
    +width:480px; /*only IE*/
    }
    3.用于内联css

    ##wrapper  {
    height:20px;   /*For Firefox*/
    *height:25px;  /*For IE7 & IE6*/
    _height:20px;  /*For IE6*/
    }
    5.IE7的hack

    >body
    html*
    *+html
    这三种写法,其中前两种都是不合法的 CSS 写法,在标准兼容浏览器中被被忽略,但是 IE7 却不这么认为。 对于 >body ,它会将缺失的选择符用全局选择符 * 代替,也就是将其处理成了 *>body,而且不光对于 > 选择符,+,~ 选择符中这个现象也存在。对于 html* ,由于 html 和 * 之间没有空格,所以也是一种 CSS 语法错误,但 IE7 不会忽略,而是错误地认为这里有一个空格。对于第三种 *+html,IE7 认为 html 前面的 DTD 声明也是一个元素,所以 html 会被选中,这三种方法中只有这一种方法是合法的 CSS 写法,也就是说可以通过校验器的验证,因此也是作者推荐的 hack 用法。
    6.IE6 不能识别

    html/* */ >body  #box { color: red; }   IE6 字体不会变成红色
    7.屏蔽IE浏览器(也就是IE下不显示)

    *:lang(zh) select {font:12px  !important;}
    /*FF,OP可见,特别提醒:由于Opera最近的升级,目前此句只为FF所识别*/
    select:empty {font:12px  !important;}

    /*safari可见*/
    这里select是选择符,根据情况更换。第二句是MAC上safari浏览器独有的。
    8.仅IE7与IE5.0可以识别

    *+html  select {…}
    当面临需要只针对IE7与IE5.0做样式的时候就可以采用这个HACK。
    9.仅IE7可以识别

    *+html  select {…!important;}
    当面临需要只针对IE7做样式的时候就可以采用这个HACK。
    10.IE6及IE6以下识别

    * html  select {…}
    这个地方要特别注意很多博客都写成了是IE6的HACK其实IE5.x同样可以识别这个HACK。其它浏览器不识别。
    html/**/ >body  select {…}
    这句与上一句的作用相同。
    11.仅IE6不识别,屏蔽IE6

    select { display /*屏蔽IE6*/:none;}
    这里主要是通过CSS注释分开一个属性与值,注释在冒号前。
    12.仅IE6与IE5不识别,屏蔽IE6与IE5

    select/**/ { display /*IE6,IE5不识别*/:none;}
    这里与上面一句不同的是在选择符与花括号之间多了一个CSS注释。不屏蔽IE5.5
    13.仅IE5不识别,屏蔽IE5

    select/*IE5不识别*/ {…}
    这一句是在上一句中去掉了属性区的注释。只有IE5不识别,IE5.5可以识别。
    14.盒模型解决方法

    select {width:IE5.x宽度; voice-family :"\"}\""; voice-family:inherit; width:正确宽度;}
    盒模型的清除方法不是通过!important来处理的。这点要明确。
    15.盒模型解决方法

    select:after {content:"."; display:block; height:0; clear:both; visibility:hidden;}
    在Firefox中,当子级都为浮动时,那么父级的高度就无法完全的包住整个子级,那么这时用这个清除浮动的HACK来对父级做一次定义,那么就可以解决这个问题。
    16.只有Opera识别

    @media all and (min-width: 0px){ select {……} }
    针对Opera浏览器做单独的设定。
    17.IE5.x的过滤器,只有IE5.x可见

    @media tty {
    i{content:"\";/*" "*/}} @import 'ie5win.css'; /*";}
    }/* */
    18.IE5/MAC的过滤器,一般用不着

    @media all and (min-width: 0px){ select {……} }
    针对Opera浏览器做单独的设定。

      >>如有疑问,欢迎进入SEO俱乐部论坛参与讨论。
  • 上一篇:div容器100%显示
    下一篇:css 兼容标签对校表
  • 推荐文章
  • SEO常见问题解答
  • 赞助商链接
对本站如有版权争议,请给我们来信并说明源由,我们将在三个工作日内作出处理。E-mail:seoclub#seoclub.net   | 关于SeoClub | 网站地图
本站法律顾问:黄锋  ◎SeoClub.net all rights reserved.  粤ICP备08001990号