vue-h5-template/vite.config.mts
2025-11-08 10:32:15 +08:00

91 lines
2.9 KiB
TypeScript

import { createVitePlugins } from './build/vite/plugins';
import type { ConfigEnv, UserConfig } from 'vite';
import { loadEnv } from 'vite';
import { wrapperEnv } from './build/utils';
import { fileURLToPath, URL } from 'node:url';
import { readdirSync, statSync } from 'node:fs';
import { dirname } from 'node:path';
// https://vitejs.dev/config/
export default function ({ command, mode }: ConfigEnv): UserConfig {
const isProduction = command === 'build';
const root = process.cwd();
const env = loadEnv(mode, root);
const viteEnv = wrapperEnv(env);
const devOptimizeDepsInclude: Array<string> = ['eruda', 'vant/es,@varlet/ui'];
if (!isProduction) {
const excludedDirs = ['utils', 'style', 'composables'];
const __dirname = dirname(fileURLToPath(import.meta.url));
// 需要自动优化的 UI 库
const uiLibraries = [
{ name: 'vant/es', path: 'node_modules/vant/es' },
{ name: '@nutui/nutui/dist/packages', path: 'node_modules/@nutui/nutui/dist/packages' },
{ name: '@varlet/ui/es', path: 'node_modules/@varlet/ui/es' },
];
uiLibraries.forEach((lib) => {
try {
const dirNames = readdirSync(`${__dirname}/${lib.path}`);
dirNames
.filter((dirName) => {
const fullPath = `${__dirname}/${lib.path}/${dirName}`;
const isDir = statSync(fullPath).isDirectory();
const isExcluded = excludedDirs.includes(dirName);
return isDir && !isExcluded;
})
.forEach((dirName) => {
if (lib.name === '@nutui/nutui/dist/packages') {
if (dirName !== 'locale') {
devOptimizeDepsInclude.push(`${lib.name}/${dirName}/style/css`);
}
} else if (lib.name === 'vant/es') {
devOptimizeDepsInclude.push(`${lib.name}/${dirName}/style/index`);
} else {
devOptimizeDepsInclude.push(`${lib.name}/${dirName}/style/index.mjs`);
}
});
} catch (err) {
console.warn(`Failed to read directory for ${lib.name}: ${err}`);
}
});
}
return {
base: '/',
root,
resolve: {
alias: { '@': fileURLToPath(new URL('./src', import.meta.url)), '#': fileURLToPath(new URL('./types', import.meta.url)) },
},
server: {
host: true,
hmr: true,
},
plugins: createVitePlugins(viteEnv, isProduction),
build: {
minify: 'terser',
terserOptions: {
compress: {
//生产环境时移除console
drop_console: true,
drop_debugger: true,
},
},
},
css: {
preprocessorOptions: {
scss: {
quietDeps: true,
silenceDeprecations: ['legacy-js-api'],
// 配置 nutui 全局 scss 变量
additionalData: `@use "@nutui/nutui/dist/styles/variables.scss" as *; @use '@/styles/vant.scss' as *;`,
},
},
},
optimizeDeps: {
include: [...devOptimizeDepsInclude],
},
};
}