浏览器兼容问题
2017-08-06 本文已影响11人
蛋黄肉
什么是 CSS hack
CSS hack由于不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等,或者是同一厂商的浏览器的不同版本,如IE6和IE7,对CSS的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。 这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。
谈一谈浏览器兼容的思路
- 渐进增强:先让低版本的浏览器要能够使用基本功能,再针对高版本的现代浏览器进行效果,交互等改进,追加更多功能达到更好的交互效果。
- 优雅降级:一开始就构建完整的功能,再针对低版本的浏览器进行兼容。
列举5种以上浏览器兼容的写法
- 使用html5shiv.js在不支持HTML5的浏览器上模拟HTML5元素;
- 使用条件注释为当前浏览器选择要加载的CSS文件;
- 使用条件注释为html标签添加不同的class属性,在CSS中在html相应的class中写不同浏览器能够兼容的属性。
- 使用Modernizr来检测浏览器支持哪些CSS属性或者不支持那些CSS属性,写在html元素中,写CSS代码时根据html标签中不同的类写不用的浏览器能够兼容的属性。
- 选择相应的框架来实现浏览器兼容,如要兼容IE6,7时尽量使用JQuery 1.~版本。
- 使用不同的前缀或者后缀,如
.box {
display: inline-block; /*主流浏览器*/
*display: inline; /*兼容IE6,7*/
*zoom: 1; /*兼容IE6,7*/
}
以下工具/名词是做什么的
- 条件注释
在HTML源码中被IE有条件解释的语句。条件注释可被用来向IE提供及隐藏代码。
例如:
<!--[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]-->
- 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对象上以及<html>元素上的类。可以帮助我们更加简单的解决浏览器的兼容性问题。 - postCSS
将标准的CSS转化为带有前缀的各个浏览器都能识别的属性;
一般在哪个网站查询属性兼容性?
caniuse.com