本日引见
webpack
怎样编译
ES6
的种种函数和语法。敲黑板:
这是webpack4
版本哦, 有一些不同于webpack3
的处所。
1. 相识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()
。
2. 装置相干库
此次,我们的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"
}
}
3. 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"
}
}
]
}
};
4. 末了: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
范例的老浏览器中看到结果了。
5. 相干材料
迎接手艺交流,援用请说明出处。
个人网站:
Yuan Xin原文链接:
webpack4 系列教程(二): 编译 ES6