View on GitHub

Cycle263 Blog

Stay hungry, stay foolish.

babel

Babel是一个广泛使用的转码器,可以将ES6代码转为ES5代码,jsx转换成js,从而在现有环境执行。

babel流程

-----------           -----------    ----------
|   parse   | -> AST -> | transform | -> | generate | -> JS
-----------           -----------    ----------

使用babel

babel配置文件.babelrc

babel-polyfill

Babel默认只转换新的JavaScript句法(syntax, 例如:class、箭头函数、rest 参数、函数默认值、解构赋值等),而不转换新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比如Object.assign、Array.from)都不会转码。

如果想让这个方法运行,必须使用babel-polyfill,为当前环境提供一个腻子。Babel默认不转码的API非常多,详细清单可以查看babel-plugin-transform-runtime模块的definitions.js文件。

备注:Babel也可以用于浏览器环境。但是,从Babel 6.0开始,不再直接提供浏览器版本,而是要用构建工具构建出来。