压缩代码
js 压缩
目前最成熟的 JavaScript 代码压缩工具是 UglifyJS, 它会分析 JavaScript 代码语法树,理解代码含义,从而能做到诸如去掉无效代码、去掉日志输出代码、缩短变量名等优化。
webpack v5 带有最新版本的 terser-webpack-plugin。底层就是使用 UglifyJS 实现。
样式文件压缩
CSS 代码也可以像 JS 那样被压缩,目前比较成熟可靠的 CSS 压缩工具是 cssnano,cssnano 是能理解 CSS 代码的含义,而不仅仅是删掉空格,例如:
对于 webpack v5 或更高版本,官方推荐使用 CssMinimizerWebpackPlugin,该插件是使用 cssnano 优化和压缩 CSS,支持缓存和并发模式下运行。
install
npm install css-minimizer-webpack-plugin --save-dev
用法
const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");
module.exports = {
// ...
optimization: {
minimizer: [
// 在 webpack@5 中,你可以使用 `...` 语法来扩展现有的 minimizer(即 `terser-webpack-plugin`),将下一行取消注释
`...`,
new CssMinimizerPlugin(),
],
},
};
压缩 HTML
HtmlWebpackPlugin 插件除了可以帮助我们简化 HTML 文件的创建,也可以压缩 HTML 文件。
在生产模式下(production),默认为对html文件进行压缩。 install
npm install --save-dev html-webpack-plugin
用法
const HtmlWebpackPlugin = require("html-webpack-plugin");
module.exports = {
plugins: [new HtmlWebpackPlugin()],
};
图片压缩
image-webpack-loader
安装报错,待使用。
base64
url-loader 功能类似于 file-loader,但是在文件大小(单位 byte)低于指定的限制时,可以返回一个 DataURL。 install
npm install --save-dev url-loader
用法
module.exports = {
module: {
rules: [
{
test: /\.(png|jpg|gif)$/,
use: [
{
loader: 'url-loader',
options: {
limit: 8192 // 作为数据URL的内联文件的字节限制
}
}
]
}
]
}
}
结果:
export default ""