import { fileURLToPath, URL } from 'node:url' import { defineConfig } from 'vite' import vue from '@vitejs/plugin-vue' import vueJsx from '@vitejs/plugin-vue-jsx' import vueDevTools from 'vite-plugin-vue-devtools' import AutoImport from 'unplugin-auto-import/vite' import Components from 'unplugin-vue-components/vite' import { AntDesignVueResolver } from 'unplugin-vue-components/resolvers' // https://vite.dev/config/ export default defineConfig({ plugins: [ vue(), vueJsx(), vueDevTools(), AutoImport({ imports: [ 'vue', 'vue-router', 'pinia', ], resolvers: [ AntDesignVueResolver({ importStyle: 'less', // 可选: 'css' | 'less',根据你是否启用了 less 主题定制 }), ], dts: 'src/types/auto-imports.d.ts', dirs: [ 'src/components', 'src/stores', ], vueTemplate: true, }), Components({ dirs: ['src/components'], extensions: ['vue', 'tsx'], dts: 'src/types/components.d.ts', deep: true, directoryAsNamespace: false, resolvers: [ AntDesignVueResolver({ importStyle: 'less', // 保持与 AutoImport 中一致 }), ], }), ], resolve: { alias: { '@': fileURLToPath(new URL('./src', import.meta.url)) }, }, })