chore(build): 只有生产模式下才开启vue.config.js

This commit is contained in:
2026-01-06 14:33:29 +08:00
parent 548aeed7b7
commit 5d34f00b3e

View File

@@ -2,88 +2,88 @@ const { zionUniMpLoadPackagePlugin } = require('zion-uniapp-mp-load-package/webp
module.exports = { module.exports = {
productionSourceMap: false, productionSourceMap: false,
configureWebpack: config => { configureWebpack: config => {
console.log('开始尝试配置极限压缩'); console.log('config.mode = ', config.mode);
if (config.mode === 'production') {
console.log('开始尝试配置极限压缩');
// 配置zion-uniapp-mp-load-package插件
config.plugins.push(new zionUniMpLoadPackagePlugin({
optimization: {
minimize: true,
moduleIds: 'named'
},
packages: [
'pages',
'pages_tool',
'pages_goods',
'pages_order',
'pages_promotion'
]
}));
// 配置zion-uniapp-mp-load-package插件 // 确保minimizer数组存在
config.plugins.push(new zionUniMpLoadPackagePlugin({ if (config.optimization && config.optimization.minimizer && Array.isArray(config.optimization.minimizer)) {
optimization: { // 查找TerserWebpackPlugin实例而不是依赖索引
minimize: true, const terserPluginIndex = config.optimization.minimizer.findIndex(plugin => {
moduleIds: 'named' return plugin.constructor && plugin.constructor.name === 'TerserWebpackPlugin' ||
}, (plugin.options && plugin.options.terserOptions);
packages: [ });
'pages',
'pages_tool',
'pages_goods',
'pages_order',
'pages_promotion'
]
}));
// 确保minimizer数组存在 if (terserPluginIndex !== -1) {
if (config.optimization && config.optimization.minimizer && Array.isArray(config.optimization.minimizer)) { // 确保options对象存在
// 查找TerserWebpackPlugin实例而不是依赖索引 if (!config.optimization.minimizer[terserPluginIndex].options) {
const terserPluginIndex = config.optimization.minimizer.findIndex(plugin => { config.optimization.minimizer[terserPluginIndex].options = {};
return plugin.constructor && plugin.constructor.name === 'TerserWebpackPlugin' || }
(plugin.options && plugin.options.terserOptions);
});
if (terserPluginIndex !== -1) { // 设置terserOptions - 极限压缩配置
// 确保options对象存在 config.optimization.minimizer[terserPluginIndex].options.terserOptions = {
if (!config.optimization.minimizer[terserPluginIndex].options) { compress: {
config.optimization.minimizer[terserPluginIndex].options = {}; drop_console: true, // 去除所有console语句
drop_debugger: true, // 去除debugger语句
dead_code: true, // 移除死代码
unused: true, // 移除未使用的变量
toplevel: true, // 清理顶层作用域未使用的变量
passes: 5, // 增加压缩次数以获得更好的压缩效果
sequences: true, // 合并连续的变量声明
evaluate: true, // 提前计算常量表达式
reduce_vars: true, // 合并或移除变量
join_vars: true, // 合并变量声明
conditionals: true, // 优化条件表达式
comparisons: true, // 优化比较操作
booleans: true, // 优化布尔表达式
typeofs: true, // 优化typeof操作
collapse_vars: true, // 折叠定义后不再修改的变量
reduce_funcs: true, // 合并或移除未使用的函数
inline: true, // 内联简单函数
side_effects: true, // 移除有副作用的代码
keep_fargs: false, // 移除未使用的函数参数
keep_fnames: false, // 不保留函数名称
pure_funcs: ['console.log', 'console.warn', 'console.error', 'console.info'], // 标记为纯函数的console方法
pure_getters: true // 假设getter函数没有副作用
},
format: {
ascii_only: true, // 确保输出ASCII字符
comments: false, // 去除所有注释
beautify: false, // 不美化输出
ecma: 5, // 输出兼容ECMAScript 5
wrap_func_args: false, // 不包裹函数参数
bracketize: true, // 使用大括号包裹所有块
quote_style: 1 // 使用单引号
},
parse: {
ecma: 8, // 使用ECMAScript 8解析
bare_returns: true // 允许顶级return语句
},
mangle: {
toplevel: true, // 混淆顶层作用域的变量名
keep_fnames: false, // 不保留函数名称
keep_classnames: false // 不保留类名称
},
module: false, // 不是ES模块
sourceMap: false // 不生成source map
};
console.log('配置极限压缩完成');
} }
// 设置terserOptions - 极限压缩配置
config.optimization.minimizer[terserPluginIndex].options.terserOptions = {
compress: {
drop_console: true, // 去除所有console语句
drop_debugger: true, // 去除debugger语句
dead_code: true, // 移除死代码
unused: true, // 移除未使用的变量
toplevel: true, // 清理顶层作用域未使用的变量
passes: 5, // 增加压缩次数以获得更好的压缩效果
sequences: true, // 合并连续的变量声明
evaluate: true, // 提前计算常量表达式
reduce_vars: true, // 合并或移除变量
join_vars: true, // 合并变量声明
conditionals: true, // 优化条件表达式
comparisons: true, // 优化比较操作
booleans: true, // 优化布尔表达式
typeofs: true, // 优化typeof操作
collapse_vars: true, // 折叠定义后不再修改的变量
reduce_funcs: true, // 合并或移除未使用的函数
inline: true, // 内联简单函数
side_effects: true, // 移除有副作用的代码
keep_fargs: false, // 移除未使用的函数参数
keep_fnames: false, // 不保留函数名称
pure_funcs: ['console.log', 'console.warn', 'console.error', 'console.info'], // 标记为纯函数的console方法
pure_getters: true // 假设getter函数没有副作用
},
format: {
ascii_only: true, // 确保输出ASCII字符
comments: false, // 去除所有注释
beautify: false, // 不美化输出
ecma: 5, // 输出兼容ECMAScript 5
wrap_func_args: false, // 不包裹函数参数
bracketize: true, // 使用大括号包裹所有块
quote_style: 1 // 使用单引号
},
parse: {
ecma: 8, // 使用ECMAScript 8解析
bare_returns: true // 允许顶级return语句
},
mangle: {
toplevel: true, // 混淆顶层作用域的变量名
keep_fnames: false, // 不保留函数名称
keep_classnames: false // 不保留类名称
},
module: false, // 不是ES模块
sourceMap: false // 不生成source map
};
console.log('配置极限压缩完成');
} }
} }
} }