vite.config.ts 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. import { fileURLToPath, URL } from 'node:url'
  2. import { defineConfig,loadEnv } from 'vite'
  3. import vue from '@vitejs/plugin-vue'
  4. import vueRouter from 'unplugin-vue-router/vite'
  5. import vueLayouts from 'vite-plugin-vue-layouts'
  6. import vueComponents from 'unplugin-vue-components/vite'
  7. import autoImports from 'unplugin-auto-import/vite'
  8. import Unocss from 'unocss/vite'
  9. import { NaiveUiResolver } from 'unplugin-vue-components/resolvers'
  10. import Components from 'unplugin-vue-components/vite'
  11. export default defineConfig(({ mode }) => {
  12. const viteEnv = loadEnv(mode, process.cwd())
  13. const { VITE_PUBLIC_PATH, VITE_PROXY_TARGET } = viteEnv
  14. return {
  15. base: VITE_PUBLIC_PATH || '/',
  16. plugins: [
  17. vueRouter(),
  18. vue(),
  19. Unocss(),
  20. vueLayouts(),
  21. vueComponents(),
  22. autoImports({
  23. imports: ['vue', 'vue-router', 'vue-i18n', {
  24. 'naive-ui': [
  25. 'useDialog',
  26. 'useMessage',
  27. 'useNotification',
  28. 'useLoadingBar'
  29. ]
  30. }],
  31. }),
  32. Components({
  33. resolvers: [NaiveUiResolver()]
  34. })
  35. ],
  36. resolve: {
  37. alias: {
  38. '@': fileURLToPath(new URL('./src', import.meta.url)),
  39. },
  40. },
  41. server: {
  42. host: '0.0.0.0',
  43. port: 3300,
  44. open: false,
  45. proxy: {
  46. '/api': {
  47. target: VITE_PROXY_TARGET,
  48. changeOrigin: true,
  49. rewrite: path => path.replace(/^\/api/, ''),
  50. secure: false,
  51. // configure: (proxy, options) => {
  52. // // 配置此项可在响应头中看到请求的真实地址
  53. // proxy.on('proxyRes', (proxyRes, req) => {
  54. // proxyRes.headers['x-real-url'] = new URL(req.url || '', options.target)?.href || ''
  55. // })
  56. // },
  57. },
  58. },
  59. },
  60. }
  61. })