vite.config.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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. "/replenishers",
  41. "/menu"
  42. ];
  43. // 动态生成代理配置
  44. const proxyConfig: Record<string, any> = {};
  45. apiPaths.forEach(path => {
  46. proxyConfig[path] = {
  47. target: API_BASE_URL,
  48. changeOrigin: true,
  49. rewrite: (p: string) => p.replace(new RegExp(`^${path}`), path)
  50. };
  51. });
  52. return {
  53. base: VITE_PUBLIC_PATH,
  54. root,
  55. resolve: {
  56. alias
  57. },
  58. // 服务端渲染
  59. server: {
  60. port: 8888,
  61. host: "0.0.0.0",
  62. proxy: proxyConfig,
  63. // 预热文件以提前转换和缓存结果,降低启动期间的初始页面加载时长并防止转换瀑布
  64. warmup: {
  65. clientFiles: ["./index.html", "./src/{views,components}/*"]
  66. }
  67. },
  68. plugins: getPluginsList(VITE_CDN, VITE_COMPRESSION),
  69. // https://cn.vitejs.dev/config/dep-optimization-options.html#dep-optimization-options
  70. optimizeDeps: {
  71. include,
  72. exclude
  73. },
  74. build: {
  75. // https://cn.vitejs.dev/guide/build.html#browser-compatibility
  76. target: "es2015",
  77. sourcemap: false,
  78. // 消除打包大小超过500kb警告
  79. chunkSizeWarningLimit: 4000,
  80. rollupOptions: {
  81. input: {
  82. index: pathResolve("./index.html", import.meta.url)
  83. },
  84. // 静态资源分类打包
  85. output: {
  86. chunkFileNames: "static/js/[name]-[hash].js",
  87. entryFileNames: "static/js/[name]-[hash].js",
  88. assetFileNames: "static/[ext]/[name]-[hash].[ext]"
  89. }
  90. }
  91. },
  92. define: {
  93. __INTLIFY_PROD_DEVTOOLS__: false,
  94. __APP_INFO__: JSON.stringify(__APP_INFO__)
  95. }
  96. };
  97. };