• CSS兼容问题资料汇集


    CSS兼容问题一直困扰着CSSer,面对各浏览器,往往感觉束手无策,愁眉不展。CSS Hack是在标准CSS没办法兼容各浏览器显示效果时才会用上的补救方法,在各浏览器厂商解析CSS没有达成一致前,我们只能用这样的方法来完成这样的任务。
      
      我进行前端开发的时候,测试用的浏览器大致有: IE7、IE6、Opera9(文章撰写时版本为9.25 8825),Safari3(文章撰写时版本为3.0.4 523.15),Firefox2(文章撰写时版本为2.0.0.11)等。
      
      在正常的 selector { property:value; } 的基础上常会根据具体情况为相同元素使用Hack以达到浏览器间统一。

     

    IE系列

      selector { +property:value; } 在属性名前加上加号”+”,这个Hack只有IE系列可以识别.�
      selector { *property:value; } 在属性名前加上星号”*”,这个Hack只有IE系列可以识别.�
      selector { _property:value; } 在属性名前加上下划线”_”,这个Hack只有IE系列 (除IE7外) 识别.�
      * html selector{ property:value; } 在选择器上运用继承法 * html selector, 这个Hack只有IE系列 (除IE7外) 可以识别.�
      html >body  selector { property:value; } 在选择器上运用继承法 html >body  selector ,这个Hack只有IE系列 (除IE7外) 可以识别.�
      selector { property:value; } 在属性名和冒号”:”之间加入注释,屏蔽IE6用.�
      selector { property:value; } 在选择器和花括号”{“之间以及在属性名和冒号”:”之间加入注释,屏蔽IE5和IE6用 (不屏蔽IE5.5) .�
      select { property:value; } 在选择器和花括号”{“之间加入注释,屏蔽IE5用.�
      *+html  selector { property:value !important; } 在选择器上运用继承法 *+html selector 再加上 !important, 这个Hack只有IE7可以识别. 

    Firefox:

      *:lang(lang) selector { property:value !important; } 用伪类lang(语言)再加上!important进行定义的话,目前只有Firefox可以识别. 

    Safari:

      selector:empty { property:value !important; } 用伪类empty再加上!important进行定义的话,目前只有Safari可以识别. 

    Opera:

      @media all and (min- 0px){ selector { property:value; } } 利用特殊继承法进行定义的话,目前只有Opera可以识别. 

      以上的CSS Hack并不完整,欢迎大家一起补充。
      对于Hack的运用,最普遍的现象是CSS盒模型Hack,清除浮动Hack。

    CSS盒模型在IE5.X上是有严重解析错误的.这个Hack针对IE5.X:

      selctor { IE5.X宽度; voice-family :””}””; voice-family:inherit; 正确宽度; }

    清除浮动Hack,相信这个定义用的人很多:

      selector:after { content:”.”; display:block; height:0; clear:both; visibility:hidden; }

    ps:http://blog.bingo929.com/at-present-very-comprehensive-information-on-css-compatible-pool.html

  • 相关阅读:
    jquery validate自定义checkbox验证规则和样式
    【转】maven导出项目依赖的jar包
    maven web项目build失败
    【转】maven仓库快速镜像
    【转】javax.net.ssl.SSLHandshakeException(Cas导入证书)
    Maven发布web项目到tomcat
    tomcat启动是报Multiple Contexts have a path of "/XXX"
    spring无法扫描jar包的问题
    CAS单点登录之mysql数据库用户验证及常见问题
    搭建CAS单点登录服务器
  • 原文地址:https://www.cnblogs.com/zytrue/p/8494417.html
Copyright © 2020-2023  润新知