今天介紹
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. 相關資料
- polyfill 引入:https://www.babeljs.cn/docs/usage/polyfill/
- babel-preset-env 配置:https://www.babeljs.cn/docs/plugins/preset-env/
歡迎技術交流,引用請註明出處。
個人網站:Yuan Xin
原文連結:webpack4 系列教程(二): 編譯 ES6