# vite.config.mts 基础配置 如果你的 `Vue Router` 模式是 hash ```javascript base: './', ``` 如果你的 `Vue Router` 模式是 history 这里的 base 和你的 `Vue Router` `base` **保持一致** ```javascript base: '/app/', ``` 完整配置: ```javascript 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 = ["eruda"]; // 开发环境自动扫描 UI 库组件目录,优化依赖预构建 if (!isProduction) { 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" }, ]; // ...自动将组件样式加入 optimizeDeps.include } 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: { // 配置 nutui 全局 scss 变量 additionalData: `@use "@/styles/variable.scss" as *;@use "@nutui/nutui/dist/styles/variables.scss" as *;`, quietDeps: true, }, }, }, optimizeDeps: { include: [...devOptimizeDepsInclude], }, }; } ``` ## optimizeDeps 说明 项目在开发环境下会自动扫描 Vant、NutUI、Varlet 组件目录,将组件样式文件加入 `optimizeDeps.include`,避免首次加载组件时出现页面刷新,提升开发体验。