今天介绍
webpack
怎么编译ES6
的各种函数和语法。敲黑板:这是webpack4
版本哦, 有一些不同于webpack3
的地方。
babel
说起编译es6
,就必须提一下babel
和相关的技术生态:
babel-loader
: 负责 es6 语法转化babel-preset-env
: 包含 es6、7 等版本的语法转化规则babel-polyfill
: es6 内置方法和函数转化垫片babel-plugin-transform-runtime
: 避免 polyfill 污染全局变量需要注意的是, babel-loader
和babel-polyfill
。前者负责语法转化,比如:箭头函数;后者负责内置方法和函数,比如:new Set()
。
这次,我们的package.json
文件配置如下:
{"devDependencies": {"babel-core": "^6.26.3","babel-loader": "^7.1.5","babel-plugin-transform-runtime": "^6.23.0","babel-preset-env": "^1.7.0","webpack": "^4.15.1"},"dependencies": {"babel-polyfill": "^6.26.0","babel-runtime": "^6.26.0"}}
webpack
中使用babel
babel
的相关配置,推荐单独写在.babelrc
文件中。下面,我给出这次的相关配置:
{"presets": [["env",{"targets": {"browsers": ["last 2 versions"]}}]],"plugins": ["transform-runtime"]}
在webpack
配置文件中,关于babel
的调用需要写在module
模块中。对于相关的匹配规则,除了匹配js
结尾的文件,还应该去除node_module/
文件夹下的第三库的文件(发布前已经被处理好了)。
module.exports = {entry: {app: "./app.js"},output: {filename: "bundle.js"},module: {rules: [{test: /\.js$/,exclude: /(node_modules)/,use: {loader: "babel-loader"}}]}};
babel-polyfill
我们发现整个过程中并没有使用babel-polyfill
。它需要在我们项目的入口文件中被引入,或者在webpack.config.js
中配置。这里我们采用第一种方法编写app.js
:
import "babel-polyfill";let func = () => {};const NUM = 45;let arr = [1, 2, 4];let arrB = arr.map(item => item * 2);console.log(arrB.includes(8));console.log("new Set(arrB) is ", new Set(arrB));
命令行中进行打包,然后编写html
文件引用打包后的文件即可在不支持es6
规范的老浏览器中看到效果了。