vite.config.ts 中
方式一
使用 esbuild
build: {
outDir: "dist",
minify: "esbuild",
sourcemap: false,
chunkSizeWarningLimit: 5000,
rollupOptions: {
experimentalLogSideEffects: false,
output: {
// 最小化拆分包
manualChunks(id) {
if (id.includes("node_modules")) {
return id
.toString()
.split("node_modules/")[1]
.split("/")[0]
.toString();
}
},
experimentalMinChunkSize: 20 * 1024, //阀值设置为 20 KB,模块大小,大于20kb的才会单独打包成chunk。
chunkFileNames: "koi/js/[name]-[hash].js",
entryFileNames: "koi/js/[name]-[hash].js",
assetFileNames: "koi/[ext]/[name]-[hash].[ext]",
},
},
},
方式二
使用 terser
build: {
sourcemap: false,
minify: "terser",
chunkSizeWarningLimit: 1500,
emptyOutDir: true,
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
},
},
rollupOptions: {
output: {
manualChunks(id) {
if (id.includes("node_modules")) {
return id
.toString()
.split("node_modules/")[1]
.split("/")[0]
.toString();
}
},
chunkFileNames: (chunkInfo) => {
const facadeModuleId = chunkInfo.facadeModuleId
? chunkInfo.facadeModuleId.split("/")
: [];
const fileName =
facadeModuleId[facadeModuleId.length - 2] || "[name]";
return `js/${fileName}/[name].[hash].js`;
},
},
},
}