乐趣区

使用webpack将ES6转化ES5

babel 使用

打开 babel 官网,按教程安装 babel

  • 安装
npm install --save-dev babel-loader @babel/core  @babel/preset-env
  • 配置 rules
module: {
  rules: [{ test: /\.js$/, exclude: /node_modules/, loader: "babel-loader"}
  ]
}
  • 生成 .babelrc 文件
{"presets": ["@babel/preset-env"]
}

此时 webpack 已经能正确的将高版本的 js 语法转为低版本的语法,但是对于新增的 api 并不会转化,如 promise。这时我们就需要其他的插件

使用 polyfill 插件,对于 babel=>7.4.0 该方法弃用

  • 安装
 npm install --save @babel/polyfill
  • 修改 .babelrc

{
  "presets": [
    [
      "@babel/preset-env",
      {"useBuiltIns":"usage" // 只转化使用了的 API}
    ]
  ]
}
  • 使用 在需要转换的文件里引入 polyfill
 import "@babel/polyfill";
  • @babel/polyfill 和 @babel/preset-env 的关系

@babel/preset-env 中与 @babel/polyfill 的相关参数有 targets 和 useBuiltIns 两个

targets: 支持的目标浏览器的列表

useBuiltIns: 参数有“entry”、”usage”、false 三个值。默认值是 false,此参数决定了 babel 打包时如何处理 @babel/polyfilll 语句。

“entry”: 会将文件中 import‘@babel/polyfilll’语句 结合 targets,转换为一系列引入语句,去掉目标浏览器已支持的 polyfilll 模块,不管代码里有没有用到,只要目标浏览器不支持都会引入对应的 polyfilll 模块。

“usage”: 不需要手动在代码里写 import‘@babel/polyfilll’,打包时会自动根据实际代码的使用情况,结合 targets 引入代码里实际用到 部分 polyfilll 模块

false: 对 import‘@babel/polyfilll’不作任何处理,也不会自动引入 polyfilll 模块

使用 plugin-transform-runtime

  • 安装
npm install --save-dev @babel/plugin-transform-runtime
  • 修改 .babelrc
{
"presets": [
    ["@babel/preset-env"]
  ],
  "plugins": [
    [
      "@babel/plugin-transform-runtime",
      {
        "absoluteRuntime": false,
        "corejs": 3,
        "helpers": true,
        "regenerator": true,
        "useESModules": false
      }
    ]
  ]
}

注意上面 corejs 设置项,不同的值需要不同的依赖包

corejs 的值 需要安装的依赖包
false npm install –save @babel/runtim
2 npm install –save @babel/runtime-corejs2
3 npm install –save @babel/runtime-corejs3
退出移动版