mirror of
https://github.com/sunniejs/vue-h5-template.git
synced 2025-09-09 15:40:04 +08:00
48 lines
1.3 KiB
TypeScript
48 lines
1.3 KiB
TypeScript
import { createVitePlugins } from './build/vite/plugins';
|
|
import { resolve } from 'path';
|
|
import type { ConfigEnv, UserConfig } from 'vite';
|
|
import { loadEnv } from 'vite';
|
|
import { wrapperEnv } from './build/utils';
|
|
import { fileURLToPath, URL } from 'node:url';
|
|
|
|
// 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);
|
|
|
|
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 *;`,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
}
|