1、Webpack性能優化 一、能夠減小webpack打包時間 二、能夠減小webpack打出來包體積 優化loader 對於 Loader 來講,影響打包效率首當其衝必屬 Babel 了。由於 Babel
會將代碼轉爲字符串生成 AST ,而後對 AST 繼續進行轉變最後再生成新的
代碼,項目越大,轉換代碼越多,效率就越低。固然了,咱們是有辦法優化的
優化 Loader 的文件搜索範圍node
module.exports = {
module: {
rules: [
{
// js 文件才使用 babel
test: /.js$/,
loader: 'babel-loader',
// 只在 src 文件夾下查找
include: [resolve('src')],
// 不會去查找的路徑
exclude: /node_modules/
}
]
}webpack
固然這樣作還不夠,咱們還能夠將 Babel 編譯過的文件緩存起來,下次只須要編譯更改
過的代碼文件便可,這樣能夠大幅度加快打包時間
二 、HappyPack
因爲受限於 Node 是單線程運行的,因此 Webpack 在打包的過程當中也是單線程
的,特別是在執行 Loader 的時候,長時間編譯的任務不少,這樣就會致使等
待的狀況。HappyPack 能夠將 Loader 的同步執行轉換爲並行的,這樣就能充分利用系
統資源來加快打包效率了
如
module: {
loaders: [
{
test: /.js$/,
include: [resolve('src')],
exclude: /node_modules/,
// id 後面的內容對應下面
loader: 'happypack/loader?id=happybabel'
}
] },
plugins: [
new HappyPack({
id: 'happybabel',
loaders: ['babel-loader?cacheDirectory'],
// 開啓 4 個線程
threads: 4
})
]
等web