Webpack 是一个强大的模块打包工具,广泛应用于现代前端开发中。随着项目规模的增大,Webpack 的构建速度和输出文件的优化变得尤为重要。
Webpack 优化的主要目标包括:
在优化之前,需要分析构建性能,找出瓶颈。常用的工具有:
stats
配置生成构建报告。// webpack.config.js
module.exports = {
// ...
stats: 'verbose', // 输出详细的构建信息
};
swc-loader
或 esbuild-loader
替代 babel-loader
,提升 JavaScript 编译速度。cache-loader
或 thread-loader
并行处理任务。module.exports = {
module: {
rules: [
{
test: /\.js$/,
use: [
'thread-loader', // 多线程处理
'babel-loader',
],
},
],
},
};
cache
选项缓存构建结果,避免重复构建。module.exports = {
cache: {
type: 'filesystem', // 使用文件系统缓存
},
};
resolve.alias
减少模块解析时间。module.noParse
跳过对某些库的解析。module.exports = {
resolve: {
alias: {
react: path.resolve(__dirname, 'node_modules/react'),
},
},
module: {
noParse: /lodash/, // 跳过 lodash 的解析
},
};
target
指定构建目标,避免不必要的 polyfill。module.exports = {
target: 'es5', // 仅支持现代浏览器时可设置为 'es2015'
};
package.json
中设置 sideEffects: false
。module.exports = {
optimization: {
usedExports: true, // 启用 Tree Shaking
},
};
SplitChunksPlugin
将公共代码提取到单独的文件中。import()
)实现按需加载。module.exports = {
optimization: {
splitChunks: {
chunks: 'all', // 提取公共代码
},
},
};
TerserPlugin
压缩 JavaScript。CssMinimizerPlugin
压缩 CSS。const TerserPlugin = require('terser-webpack-plugin');
const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');
module.exports = {
optimization: {
minimize: true,
minimizer: [
new TerserPlugin(), // 压缩 JS
new CssMinimizerPlugin(), // 压缩 CSS
],
},
};
lodash-es
替代 lodash
,支持 Tree Shaking。day.js
替代 moment.js
,减少体积。[contenthash]
根据文件内容生成哈希,确保文件内容变化时哈希值变化。module.exports = {
output: {
filename: '[name].[contenthash].js',
},
};
react
、lodash
)提取到单独的文件中,避免业务代码变化导致缓存失效。module.exports = {
optimization: {
splitChunks: {
cacheGroups: {
vendor: {
test: /[\\/]node_modules[\\/]/,
name: 'vendors',
chunks: 'all',
},
},
},
},
};
ModuleConcatenationPlugin
将模块合并到一个函数中,减少函数声明和闭包。module.exports = {
optimization: {
concatenateModules: true, // 启用 Scope Hoisting
},
};
PurgeCSSPlugin
移除未使用的 CSS 代码。const PurgeCSSPlugin = require('purgecss-webpack-plugin');
const glob = require('glob');
module.exports = {
plugins: [
new PurgeCSSPlugin({
paths: glob.sync(`${path.join(__dirname, 'src')}/**/*`, { nodir: true }),
}),
],
};
Webpack 优化是一个系统化的过程,需要根据项目特点选择合适的策略。通过减少构建时间、减小输出文件体积、提升缓存利用率和提高代码质量,可以显著提升 Webpack 的性能和输出效果。