vite.config.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. import { getPluginsList } from "./build/plugins";
  2. import { include, exclude } from "./build/optimize";
  3. import { type UserConfigExport, type ConfigEnv, loadEnv } from "vite";
  4. import {
  5. root,
  6. alias,
  7. wrapperEnv,
  8. pathResolve,
  9. __APP_INFO__
  10. } from "./build/utils";
  11. export default ({ mode }: ConfigEnv): UserConfigExport => {
  12. const { VITE_CDN, VITE_PORT, VITE_COMPRESSION, VITE_PUBLIC_PATH } =
  13. wrapperEnv(loadEnv(mode, root));
  14. // 统一的后端服务地址
  15. const API_BASE_URL = "http://localhost:7070/admin";
  16. // 需要代理的 API 路径列表
  17. const apiPaths = [
  18. "/login",
  19. "/user",
  20. "/role",
  21. "/permission",
  22. "/users",
  23. "/shops",
  24. "/devices",
  25. "/order",
  26. "/products",
  27. "/inventory",
  28. "/marketing",
  29. "/checkin",
  30. "/announcement",
  31. "/operation-log",
  32. "/sync",
  33. "/new-product-apply",
  34. "/dashboard",
  35. "/dict",
  36. "/timed-discount",
  37. "/layer-templates",
  38. "/distribution",
  39. "/refund"
  40. ];
  41. // 动态生成代理配置
  42. const proxyConfig: Record<string, any> = {};
  43. apiPaths.forEach(path => {
  44. proxyConfig[path] = {
  45. target: API_BASE_URL,
  46. changeOrigin: true,
  47. rewrite: (p: string) => p.replace(new RegExp(`^${path}`), path)
  48. };
  49. });
  50. return {
  51. base: VITE_PUBLIC_PATH,
  52. root,
  53. resolve: {
  54. alias
  55. },
  56. // 服务端渲染
  57. server: {
  58. port: 8888,
  59. host: "0.0.0.0",
  60. proxy: proxyConfig,
  61. // 预热文件以提前转换和缓存结果,降低启动期间的初始页面加载时长并防止转换瀑布
  62. warmup: {
  63. clientFiles: ["./index.html", "./src/{views,components}/*"]
  64. }
  65. },
  66. plugins: getPluginsList(VITE_CDN, VITE_COMPRESSION),
  67. // https://cn.vitejs.dev/config/dep-optimization-options.html#dep-optimization-options
  68. optimizeDeps: {
  69. include,
  70. exclude
  71. },
  72. build: {
  73. // https://cn.vitejs.dev/guide/build.html#browser-compatibility
  74. target: "es2015",
  75. sourcemap: false,
  76. // 消除打包大小超过500kb警告
  77. chunkSizeWarningLimit: 4000,
  78. rollupOptions: {
  79. input: {
  80. index: pathResolve("./index.html", import.meta.url)
  81. },
  82. // 静态资源分类打包
  83. output: {
  84. chunkFileNames: "static/js/[name]-[hash].js",
  85. entryFileNames: "static/js/[name]-[hash].js",
  86. assetFileNames: "static/[ext]/[name]-[hash].[ext]"
  87. }
  88. }
  89. },
  90. define: {
  91. __INTLIFY_PROD_DEVTOOLS__: false,
  92. __APP_INFO__: JSON.stringify(__APP_INFO__)
  93. }
  94. };
  95. };