vite.config.ts 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import vue from '@vitejs/plugin-vue'
  2. import { resolve } from 'path'
  3. import { loadEnv } from 'vite'
  4. import type { UserConfig, ConfigEnv, ProxyOptions } from 'vite'
  5. import { isProd, customHotUpdate } from '/@/utils/vite'
  6. import { svgBuilder } from '/@/components/icon/svg/index'
  7. const pathResolve = (dir: string): any => {
  8. return resolve(__dirname, '.', dir)
  9. }
  10. // https://vitejs.cn/config/
  11. const viteConfig = ({ mode }: ConfigEnv): UserConfig => {
  12. const { VITE_PORT, VITE_OPEN, VITE_BASE_PATH, VITE_OUT_DIR, VITE_PROXY_URL } = loadEnv(mode, process.cwd())
  13. const alias: Record<string, string> = {
  14. '/@': pathResolve('./src/'),
  15. assets: pathResolve('./src/assets'),
  16. 'vue-i18n': isProd(mode) ? 'vue-i18n/dist/vue-i18n.cjs.prod.js' : 'vue-i18n/dist/vue-i18n.cjs.js',
  17. }
  18. let proxy: Record<string, string | ProxyOptions> = {}
  19. if (VITE_PROXY_URL) {
  20. proxy = {
  21. '/zskk': {
  22. target: VITE_PROXY_URL,
  23. changeOrigin: true,
  24. // rewrite: (path) => path.replace(/^\/zskk/, ""),
  25. },
  26. '/admin': {
  27. target: VITE_PROXY_URL,
  28. changeOrigin: true,
  29. // rewrite: (path) => path.replace(/^\/admin/, ""),
  30. },
  31. }
  32. }
  33. console.log('VITE_OPEN', VITE_OPEN, mode)
  34. return {
  35. plugins: [vue(), svgBuilder('./src/assets/icons/'), customHotUpdate()],
  36. root: process.cwd(),
  37. resolve: { alias },
  38. base: VITE_BASE_PATH,
  39. server: {
  40. host: '0.0.0.0',
  41. port: parseInt(VITE_PORT),
  42. open: VITE_OPEN ? '/#/admin/login' : false,
  43. proxy: proxy,
  44. },
  45. build: {
  46. cssCodeSplit: false,
  47. sourcemap: false,
  48. outDir: VITE_OUT_DIR,
  49. emptyOutDir: true,
  50. chunkSizeWarningLimit: 1500,
  51. rollupOptions: {
  52. output: {
  53. manualChunks: {
  54. // 分包配置,配置完成自动按需加载
  55. vue: ['vue', 'vue-router', 'pinia', 'vue-i18n', 'element-plus'],
  56. echarts: ['echarts'],
  57. },
  58. },
  59. },
  60. },
  61. }
  62. }
  63. export default viteConfig