vite.config.ts 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. import { defineConfig, loadEnv } from "vite"
  2. import { resolve } from "path"
  3. import createVitePlugins from "./vite/plugins"
  4. // https://vitejs.dev/config/
  5. export default defineConfig(({ mode, command }) => {
  6. const env = loadEnv(mode, process.cwd())
  7. const { VITE_APP_ENV } = env
  8. return {
  9. // 部署生产环境和开发环境下的URL。
  10. // 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上
  11. // 例如 https://www.vber.net/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.vber.net/admin/,则设置 baseUrl 为 /admin/。
  12. base: VITE_APP_ENV === "production" ? "/" : "/",
  13. plugins: createVitePlugins(env, command === "build"),
  14. resolve: {
  15. // https://cn.vitejs.dev/config/#resolve-alias
  16. alias: {
  17. "@a": resolve(__dirname, "./src/api"),
  18. "@s": resolve(__dirname, "./src/stores"),
  19. "@r": resolve(__dirname, "./src/router"),
  20. "@v": resolve(__dirname, "./src/views"),
  21. "@@": resolve(__dirname, "./src/core"),
  22. "@@@": resolve(__dirname, "./src/components"),
  23. "@com": resolve(__dirname, "./src/components"),
  24. "@": resolve(__dirname, "./src"),
  25. "~": resolve(__dirname, "./")
  26. },
  27. // https://cn.vitejs.dev/config/#resolve-extensions
  28. extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json", ".vue"]
  29. },
  30. // vite 相关配置
  31. server: {
  32. port: 6060,
  33. // host: true,
  34. host: "0.0.0.0",
  35. // 热更新
  36. hmr: true,
  37. // 设为 true 时若端口已被占用则会直接退出,而不是尝试下一个可用端口
  38. strictPort: true,
  39. open: true,
  40. proxy: {
  41. "/dev-api": {
  42. target: "http://192.168.0.82:6066",
  43. changeOrigin: true,
  44. rewrite: (p) => p.replace(/^\/dev-api/, "")
  45. }
  46. // "/dev-api": {
  47. // target: "http://192.168.0.82:6060",
  48. // changeOrigin: true,
  49. // rewrite: (p) => p.replace(/^\/dev-api/, "/prod-api")
  50. // }
  51. }
  52. },
  53. preview: {
  54. port: 6666,
  55. // host: true,
  56. host: "0.0.0.0",
  57. // 热更新
  58. hmr: true,
  59. // 设为 true 时若端口已被占用则会直接退出,而不是尝试下一个可用端口
  60. strictPort: true,
  61. open: true,
  62. proxy: {
  63. // "/prod-api": {
  64. // target: "http://localhost:6060",
  65. // changeOrigin: true,
  66. // rewrite: (p) => p.replace(/^\/prod-api/, ""),
  67. // }, 1
  68. "/prod-api": {
  69. target: "http://192.168.0.82:6066",
  70. changeOrigin: true,
  71. rewrite: (p) => p.replace(/^\/prod-api/, "/prod-api")
  72. }
  73. }
  74. }
  75. }
  76. })