浏览器兼容

什么是CSS hack

由于不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等,或者是同一厂商的浏览器的不同版本,如IE6和IE7,对CSS的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能在不同的浏览器中也能得到我们想要的页面效果。
CSS Hack大致有3种表现形式,CSS属性前缀法、选择器前缀法以及IE条件注释法(即HTML头部引用if IE)Hack,实际项目中CSS Hack大部分是针对IE浏览器不同版本之间的表现差异而引入的。

  1. 属性前缀法(即类内部Hack):例如 IE6能识别下划线""和星号" * ",IE7能识别星号" * ",但不能识别下划线"",IE6~IE10都认识"\9",但firefox前述三个都不能认识
  2. 选择器前缀法(即选择器Hack)
  3. IE条件注释法(即HTML条件注释Hack):针对所有IE(注:IE10+已经不再支持条件注释):,针对IE6及以下版本:。这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效

谈一谈浏览器兼容的思路

  1. 要不要做
    • 产品的角度(产品的受众、受众的浏览器比例、效果优先还是基本功能优先)
    • 成本的角度 (有无必要做某件事)
  2. 做到什么程度
    • 让哪些浏览器支持哪些效果
  3. 如何做

列举5种以上浏览器兼容的写法

  1. 条件注释
    条件注释 (conditional comment) 是于HTML源码中被IE有条件解释的语句。条件注释可被用来向IE提供及隐藏代码。使用了条件注释的页面在 Windows Internet Explorer 9 中可正常工作,但在 Internet Explorer 10 中无法正常工作。
<!--[if IE 6]>
<p>You are using Internet Explorer 6.</p>
<![endif]-->
<!--[if !IE]><!-->
<script>alert(1);</script>
<!--<![endif]-->
<!--[if IE 8]>
<link href="ie8only.css" rel="stylesheet">
<![endif]-->
  1. CSS hack
.box{
  color: red;
  _color: blue; /*ie6*/
  *color: pink; /*ie67*/
  color: yellow\9;  /*ie/edge 6-8*/
}
  1. 针对IE67的清除浮动方法
.clearfix{
  *zoom: 1; /* 仅对ie67有效 */
}
  1. 针对IE67的inline-block方法
.target{
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
  1. 使用兼容工具
小于ie9时生效
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->

以下工具/名词是做什么的

  • 条件注释
    是于HTML源码中被 IE 有条件解释的语句。条件注释可被用来向 IE提供及隐藏代码。 条件注释最初于微软的 Internet Explorer 5浏览器中出现,并且直至 Internet Explorer 9 均支持。IE10+不再支持条件注释。
  • IE Hack
    针对不同版本的IE浏览器写的css,从而使各个版本IE能够顺利渲染页面。
  • js 能力检测
    浏览器的能力检测目标不是检测特定的浏览器,而是检测浏览器的能力。这样,只需要检测浏览器是否支持特定的能力,就可以给出特定的解决方案。这一部分检测是解决浏览器兼容问题的主要检测。
  • html5shiv.js
    通过模拟标签解决不支持HTML5新标签,新特性的浏览器的兼容问题。IE9以下的IE版本不支持HTML5
  • respond.js
    用于为 IE6-8 以及其它不支持 CSS3 媒体查询功能的浏览器提供媒体查询的 min-width 和 max-width 特性,实现响应式网页设计
  • css reset
    将所有的浏览器的自带样式重置掉,这样更易于保持各浏览器渲染的一致性
  • normalize.css
    Normalize.css 是一个可以定制的CSS文件,它让不同的浏览器在渲染网页元素的时候形式更统一,在默认的HTML元素样式上提供了跨浏览器的高度一致性
    • Preserves useful defaults, unlike many CSS resets.
      保护有用的浏览器默认样式而不是完全去掉它们
    • Normalizes styles for a wide range of elements
      一般化的样式:为大部分HTML元素提供
    • Corrects bugs and common browser inconsistencies
      修复浏览器自身的bug并保证各浏览器的一致性
    • Improves usability with subtle improvements
      优化CSS可用性:用一些小技巧
    • Explains what code does using detailed comments
      解释代码:用注释和详细的文档来
  • Modernizr
    odernizr 是一个 JavaScript 库,用于检测用户浏览器的 HTML5 与 CSS3 特性。Modernizr 使你可以方便地为各种情况编写 JavaScript 和 CSS,无论浏览器是否支持这些特性。这是处理渐进增强的完美方案。Modernizr 会在页面加载后立即检测特性;然后创建一个包含检测结果的 JavaScript 对象,同时在 html 元素加入方便你调整 CSS 的 class 名。
  • postCSS
    是一个JS插件转换样式表的工具。这些插件能够检验你的CSS、支持变量和混合,转化css3的新特性语法、行内图片等。

查询属性兼容性的网站

https://caniuse.com/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 什么是 CSS hack CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什...
    怎么昵称阅读 406评论 0 1
  • CSS Hack 不同的浏览器对某些CSS代码解析会存在一定的差异,因此就会导致不同浏览器下给用户展示的页面效果不...
    zx9426阅读 408评论 0 0
  • 什么是CSS hack CSS hack由于不同厂商的浏览器,比如Internet Explorer,Safari...
    尾巴尾巴尾巴阅读 806评论 0 0
  • 1、什么是 CSS hack 不同厂商的浏览器(比如Internet Explorer,Safari,Mozill...
    zh_yang阅读 376评论 0 0
  • 一、前言 做前端开发,必然少不了浏览器,然而不同的厂商有着各自版本的浏览器,不同的浏览器对css的理解和解析不一样...
    青鸣阅读 517评论 0 2