2 Star 75 Fork 5

imzusheng/Wechat-Wecat

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
vue.config.js 2.74 KB
一键复制 编辑 原始数据 按行查看 历史
imzusheng 提交于 2021-11-22 23:14 . fix
const CompressionPlugin = require('compression-webpack-plugin')
const webpack = require('webpack')
module.exports = {
chainWebpack: (config) => {
if (process.env.NODE_ENV === 'production') {
config.plugin('compressionPlugin').use(new CompressionPlugin({
test: /\.(js|css)$/, // 匹配文件名
threshold: 0, // 对超过10k的数据压缩
minRatio: 0.8,
deleteOriginalAssets: true // 删除源文件
}))
}
},
configureWebpack: {
plugins: [
new webpack.ContextReplacementPlugin(/moment[/\\]locale$/, /zh-cn/)
],
optimization: {
// 模块在代码中被复用或者来自 node_modules 文件夹
// 模块的体积大于等于30kb(压缩之前)
// 当按需加载 chunks 时,并行请求的最大数量不能超过5
// 初始页面加载时,并行请求的最大数量不能超过将3
splitChunks: {
// // 表示选择哪些 chunks 进行分割,可选值有:async,initial和all
// chunks: 'all',
// // 表示新分离出的chunk必须大于等于minSize,默认为30000,约30kb。
minSize: 30000,
// // 表示一个模块至少应被minChunks个chunk所包含才能分割。默认为1。
// minChunks: 1,
// // 表示按需加载文件时,并行请求的最大数目。默认为5。
// maxAsyncRequests: 5,
// // 表示加载入口文件时,并行请求的最大数目。默认为3。
// maxInitialRequests: 3,
// // 表示拆分出的chunk的名称连接符。默认为~。如chunk~vendors.js
// automaticNameDelimiter: '~',
// // 设置chunk的文件名。默认为true。当为true时,splitChunks基于chunk和cacheGroups的key自动命名。
// name: true,
// // cacheGroups 下可以可以配置多个组,每个组根据test设置条件,符合test条件的模块,就分配到该组。模块可以被多个组引用,但最终会根据priority来决定打包到哪个组中。默认将所有来自 node_modules目录的模块打包至vendors组,将两个以上的chunk所共享的模块打包至default组。
cacheGroups: {
default: {
name: 'common',
chunks: 'all',
minChunks: 2,
priority: -11
},
node_modules: {
test: /[\\/]node_modules[\\/]/,
chunks: 'initial',
priority: -10
}
// ant_design: {
// test: /[\\/]node_modules\\ant-design-vue[\\/]/,
// chunks: 'initial',
// reuseExistingChunk: true,
// priority: -9
// }
}
}
}
},
productionSourceMap: false
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/imzusheng/Wecat.git
git@gitee.com:imzusheng/Wecat.git
imzusheng
Wecat
Wechat-Wecat
main

搜索帮助