ES6 转 ES5

那么 Babel 是如何把 ES6 转成 ES5 呢,其大致分为三步:

  • 将代码字符串解析成抽象语法树,即所谓的 AST
  • 对 AST 进行处理,在这个阶段可以对 ES6 代码进行相应转换,即转成 ES5 代码
  • 根据处理后的 AST 再生成代码字符串

 

复杂点的Promise在babel转译的时候,不仅会调整源代码,还需要引入@babel/polyfill。

有时候会遇到regeneratorRuntime is not defined这个报错,

原因是源代码中Promise部分被转译了,转译后用到的regeneratorRuntime在@babel/polyfill中,但@babel/polyfill没被引入。

posted @ 2019-07-31 10:50  安博主  阅读(424)  评论(0编辑  收藏  举报