浏览器兼容问题

2017-08-06  本文已影响11人  蛋黄肉

什么是 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*/
}

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

<!--[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]-->

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

caniuse.com

上一篇下一篇

猜你喜欢

热点阅读