打开babel官网,按教程安装babeljavascript
npm install --save-dev babel-loader @babel/core @babel/preset-env
module: { rules: [ { test: /\.js$/, exclude: /node_modules/, loader: "babel-loader" } ] }
{ "presets": ["@babel/preset-env"] }
此时webpack已经能正确的将高版本的js语法转为低版本的语法,可是对于新增的api并不会转化,如promise。这时咱们就须要其余的插件java
npm install --save @babel/polyfill
{ "presets": [ [ "@babel/preset-env", { "useBuiltIns":"usage" // 只转化使用了的API } ] ] }
import "@babel/polyfill";
@babel/preset-env 中与 @babel/polyfill 的相关参数有 targets 和 useBuiltIns 两个node
targets: 支持的目标浏览器的列表webpack
useBuiltIns: 参数有 “entry”、”usage”、false 三个值。默认值是false,此参数决定了babel打包时如何处理@babel/polyfilll 语句。web
“entry”: 会将文件中 import‘@babel/polyfilll’语句 结合 targets ,转换为一系列引入语句,去掉目标浏览器已支持的polyfilll 模块,无论代码里有没有用到,只要目标浏览器不支持都会引入对应的polyfilll 模块。npm
“usage”: 不须要手动在代码里写import‘@babel/polyfilll’,打包时会自动根据实际代码的使用状况,结合 targets 引入代码里实际用到 部分 polyfilll 模块json
false: 对 import‘@babel/polyfilll’不做任何处理,也不会自动引入 polyfilll 模块api
npm install --save-dev @babel/plugin-transform-runtime
{ "presets": [ [ "@babel/preset-env" ] ], "plugins": [ [ "@babel/plugin-transform-runtime", { "absoluteRuntime": false, "corejs": 3, "helpers": true, "regenerator": true, "useESModules": false } ] ] }
注意上面corejs设置项,不一样的值须要不一样的依赖包promise
corejs的值 | 须要安装的依赖包 |
---|---|
false | npm install --save @babel/runtim |
2 | npm install --save @babel/runtime-corejs2 |
3 | npm install --save @babel/runtime-corejs3 |