浏览器兼容问题

什么是 CSS hack

CSS hack由于不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等,或者是同一厂商的浏览器的不同版本,如IE6和IE7,对CSS的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。 这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。

谈一谈浏览器兼容的思路

  • 渐进增强:先让低版本的浏览器要能够使用基本功能,再针对高版本的现代浏览器进行效果,交互等改进,追加更多功能达到更好的交互效果。
  • 优雅降级:一开始就构建完整的功能,再针对低版本的浏览器进行兼容。

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

  1. 使用html5shiv.js在不支持HTML5的浏览器上模拟HTML5元素;
  2. 使用条件注释为当前浏览器选择要加载的CSS文件;
  3. 使用条件注释为html标签添加不同的class属性,在CSS中在html相应的class中写不同浏览器能够兼容的属性。
  4. 使用Modernizr来检测浏览器支持哪些CSS属性或者不支持那些CSS属性,写在html元素中,写CSS代码时根据html标签中不同的类写不用的浏览器能够兼容的属性。
  5. 选择相应的框架来实现浏览器兼容,如要兼容IE6,7时尽量使用JQuery 1.~版本。
  6. 使用不同的前缀或者后缀,如
.box {
  display: inline-block;   /*主流浏览器*/
  *display: inline;     /*兼容IE6,7*/
  *zoom: 1;          /*兼容IE6,7*/
}

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

  • 条件注释
    在HTML源码中被IE有条件解释的语句。条件注释可被用来向IE提供及隐藏代码。
    例如:





  • IE Hack
    IE Hack就是针对IE浏览器兼容的写法,主要目的就是使我们的网页能够兼容各个版本的IE浏览器
  • js 能力检测
    在使用js方法的时候,先判断这个方法有没有在使用。
  • html5shiv.js
    模拟HTML5标签,主要用于IE6,7,8等一些不支持HTML5的浏览器;
  • respond.js
    兼容响应式媒体查询,主要用于IE6,7;
  • css reset
    去除浏览器的默认样式;
  • normalize.css
    和css reset的用法一样,但是不再那样简单粗暴的将所有的样式去掉,而是保留了一些合理的样式。
  • Modernizr
    Modernizr测试当前浏览器的CSS3和HTML5功能,并通过两种方式使结果可用:作为全局Modernizr对象上以及元素上的类。可以帮助我们更加简单的解决浏览器的兼容性问题。
  • postCSS
    将标准的CSS转化为带有前缀的各个浏览器都能识别的属性;

一般在哪个网站查询属性兼容性?

caniuse.com

你可能感兴趣的:(浏览器兼容问题)