babel-polyfill转换新API
在新版创投圈开发中,我们使用react+redux来开发个人中心部分,但是在测试浏览器兼容性的过程中,发现了一个问题,其实在babel的文档里早就说明了这个问题,但是一直没注意到。
Babel默认只转换新的JavaScript句法(syntax),而不转换新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise
等全局对象,以及一些定义在全局对象上的方法(比如Object.assign
)都不会转码。
举例来说,ES6在Array对象上新增了Array.from方法。Babel就不会转码这个方法。如果想让这个方法运行,必须使用babel-polyfill,为当前环境提供一个垫片(不懂,啥是垫片)。
安装命令如下
1 | $ npm install --save babel-polyfill |
然后在脚本头部,加入
1 | import 'babel-polyfill'; //或者 require('babel-polyfill'); |
Babel默认不转码的API非常多,详细清单可以查看babel-plugin-transform-runtime
模块的definitions.js文件。