import { fileURLToPath, URL } from 'node:url' import UnoCSS from 'unocss/vite' import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue' import vueDevTools from 'vite-plugin-vue-devtools' import AutoImport from 'unplugin-auto-import/vite' import Components from 'unplugin-vue-components/vite' import { NaiveUiResolver } from 'unplugin-vue-components/resolvers' import vueJsx from '@vitejs/plugin-vue-jsx' import Icons from 'unplugin-icons/vite' // Vite 配置文件 export default defineConfig({ plugins: [ vue(), vueJsx(), vueDevTools(), UnoCSS(), Icons({ autoInstall: true, }), AutoImport({ imports: ['vue', 'vue-router'], resolvers: [NaiveUiResolver()], dts: 'global.types/auto-imports.d.ts', }), Components({ resolvers: [NaiveUiResolver()], dts: 'global.types/components.d.ts', }), ], resolve: { alias: { '@': fileURLToPath(new URL('./src', import.meta.url)), }, }, build: { minify: 'terser', terserOptions: { compress: { drop_console: true, drop_debugger: true, }, }, }, css: { preprocessorOptions: { scss: { additionalData: '@use "@/assets/styles/mixins.scss" as *;', }, }, }, // 开发服务器配置 server: { // 启动时自动打开浏览器 open: true, // 开发服务器端口 port: 4005, // 允许局域网访问 host: true, }, })