vite.config.ts 2.8 KB

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