从shim & polyfill谈浏览器兼容性

shim:

shim是一个库,这个库中的方法接收的参数与调用方法与标准的方法一样,但是shim中的方法是自己实现逻辑处理的,因此在方法中加入了兼容性处理。所以方法的返回结果与标准方法相同。
备注: 所谓标准方法就是你原先调用的ES5或者ES6或者其它库中的原生方法。

polyfill:

polyfill指的是符合shim标准的API。polyfill API使用老方法来实现新功能,从而保证在低级浏览器中也能使用比较新的方法。
例如: 使用ES5中的方法来实现ES6中特定的方法,从而在原本不支持ES6的浏览器也能够使用ES6中新增的特定方法。

es5-shim.js/es5-shim-min.js:

可以让一些低级的浏览器支持ES5中的一些特性。
注意: 由于es5-shim.js使用的是EMCScript的原生方法来实现的,因此必须放在所有外部导入js文件的最上面。

es6-shim.js/es6-shim-min.js:

可以让一些低级的浏览器支持ES6中的一些特性。

require(‘es6-promise’).polyfill();

这个polyfill()方法能够在全局范围内处理promise方法。每当promise方法被调用,polyfill()方法就会自动修改为在低版本浏览器中也能处理的语法。
备注: 这个方法也可以写成:require(‘es6-promise/auto’);

最后再举一个处理兼容性的例子。

html5shiv/html5shim:

由谷歌提供的html5.js能够让IE9以下的浏览器也能够正确处理html5中新增的几个标签。正确的调用方法如下:
<!--[if lt IE 9]>
    <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
注意:
1.这里的注释是不能删除的。这个条件注释用于检查当前浏览器版本是否低于IE9,只有当前浏览器版本低于IE9时,这个js文件才会被引入。
2.这个条件注释必须放在head标签能。因为IE浏览器必须在元素解析前知道这个元素。如果放在其他位置则会导致失效!
除此之外还需要在CSS样式表中添加一条样式:
header,
section,
footer,
aside,
nav,
article,
figure {
    display: block;
}
备注: 这条样式是为了让低版本的浏览器能够将html5中新增的标签当作块级元素来处理。否则低版本会将这些元素当作行级元素进行处理。

总结:作为初学者,我还有很多东西理解的不全面或者不准确,如果我理解的有偏差,请您及时指出,便于我作出修整,避免其他初学者被误导。谢谢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值