Babel 你太美。。。

Babel

为何要用 Babel

Babel 的本意是 “通天塔”。 西方神话故事里,之前的人语言相同,决定创建有个能直达上天的塔,神后面害怕人们语言相通就打乱它,让他们不能明白对方的意思,并把他们分散到各地。node

为了解决上古时代浏览器对新语法不支持、不兼容状况下。发明了 Babel ,可以将 ES6 代码 转为 ES5 代码, 从而在现有环境执行。react

安装环境

咱们将 Babel 想象成 一只多功能的笔,而咱们的配置项,就是咱们赋予笔的功能,例如:像水彩笔、像铅笔、像圆珠笔,每种笔在它的使用环境下使用。git

//这些是babel 的核心
yarn add --save-dev @babel/core @babel/cli @babel/preset-env
yarn add --save @babel/polyfill
复制代码
babel.config.js

const presets = [
  [
    "@babel/env",
    {
      targets: {
        edge: "17",
        firefox: "60",
        chrome: "67",
        safari: "11.1",
      },
      useBuiltIns: "usage",
    },
  ],
];

module.exports = { presets };

复制代码

执行方法github

./node_modules/.bin/babel src --out-dir lib  或者  npx babel
复制代码

运行原理

babel 在进行解析时以下chrome

input string -> @babel/parser parser -> AST -> transformer[s] -> AST -> @babel/generator -> output string

  用大白话讲一下就是以炒菜为例子, 咱们须要将菜放到锅里面乱炖。
  babel/core, 就是炒菜的这个过程。
  babel/cli 是锅,咱们能够在上面炒任何菜(咱们的代码), 
  咱们在炒的过程,但愿全自动炒菜(添油加醋等),
  bable/plugin 就是提供的工具,当咱们直接照着菜单自动炒的时候,
  就是 babel/preset-env。 
  有时候这个锅可能要用电,用煤气,咱们就用 babel/proyfill 作个接口兼容。
  让他能够用电、用煤气。 
  后来发现这个接电就能用,这时候 babel/runtime 就能解决,遇到要接电的才转。


  ok,再说都饿了。

  咱们再来梳理下:

  @babel/core 转换ast

  @babel/cli 打包工具

  @babel/plugin 插件机制,手动增长

  @babel/preset-env 配置环境

  @babel/polyfill 提供某些api,包含所需整个运行环境。

  @babel/runtime 按需载入所需api。

复制代码

Plugins & Presets

你可以单独引一个 js 语法特性插件作处理,例如箭头函数。应用场景在例如一个新的提案出来的时候,尝尝鲜,正常有装咱们的 Babel 全家桶足以应付了。typescript

npm install --save-dev @babel/plugin-transform-arrow-functionsnpm

npx babel src --out-dir lib --plugins=@babel/plugin-transform-arrow-functions.json

const fn = () => 1;

// converted to

var fn = function fn() {
  return 1;
};


复制代码

preset 是预设的意思,像插件同样,你也能够设置本身的预设,以共享须要的任何插件组合,api

npm install --save-dev @babel/preset-env

  npx src --out-dir lib --presets=@babel/env
复制代码

这个预设将支持 ES6, ES7 的全部插件。 并且预设也能够作配置, 咱们能够经过配置文件浏览器

const presets = [
  [
    "@babel/env",
    {
      targets: {
        edge: "17",
        firefox: "60",
        chrome: "67",
        safari: "11.1",
      },
    },
  ],
];

module.exports = { presets };

复制代码

tansform-runtime

转换器它的做用是避免编译输出中的重复。运行时将编译到您的构建中。 还有另外一个做用是为代码建立沙盒环境,若是直接导入 core-js 或者 babel/prolyfill。

npm install --save-dev @babel/plugin-transform-runtime npm install --save @babel/runtime

变换器将这些内置函数为core-js, 而不须要使用polyfill

{
  "plugins": [
    [
      "@babel/plugin-transform-runtime",
      {
        "absoluteRuntime": false,
        "corejs": false,
        "helpers": true,
        "regenerator": true,
        "useESModules": false
      }
    ]
  ]
}

复制代码

polyfill

env 预设仅加载咱们的目标浏览器中不可用的功能转换插件。 @babel/prolyfill模块包括core.js和自定义 regenerator,模拟完成的 es2015 环境。 也就是说你可使用内置函数,静态方法等。

npm install --save @babel/polyfill

Babel 是处于构建期, 转译出来的结果在默认下并不包括 ES6 对运行时的扩展,例如 builtins , 内建类型上的原型扩展 Array、Object、String ,Regenerator 等。

api 指的是咱们能够经过函数从新覆盖的语法,例如 Promise,includes等。

syntax, 指的是let, const, class等, 没法重写。

因此须要 plyfill 来处理。

polyfill 与 transform-runtime 的区别。

babel-runtime 库 是由Babel提供的polyfill库, 它自己就是由core-js 与 regenerator-runtime 库组成。

咱们能够经过 babel-plugin-transform-runtime 进行引用

babel 配置

configuration配置方法 能够有如下状况:

  • .babelrc (and .babelrc.js) files
  • package.json files with a "babel" key

babel 与 react 常见配置

yarn add @babel/preset-es2015 @babel/preset-react - -save-dev

yarn add @babel/preset-react-hmre - -save -dev

.babelrc
{
"presets":[
  "es2015",
  "react",
  "@babel/preset-env"],
"env":{
    "development":{
      "presets":["react-hmre"]
    }
  }
//
}
复制代码

babel 与 TypeScript

yarn add @babel/plugin-tansform-typescript yarn add @babel/preset-typescript

{
  "presets": ["@babel/preset-typescript"]
}

配置清单




复制代码

babel 还能作什么

后记

欢迎关注微信公众号!,进行更好的交流。
复制代码

微信

参考资料

如下是一些参考资料:

[@babel/core](https://babeljs.io/docs/en/babel-core)

[babel options api](https://babeljs.io/docs/en/options)

[babel.config.js](https://github.com/babel/babel/blob/master/babel.config.js)

[babel/core.js](https://github.com/zloirock/core-js)

[babel regenerator-runtimer](https://github.com/facebook/regenerator/blob/master/packages/regenerator-runtime/runtime.js)
复制代码
相关文章
相关标签/搜索