vite.config.ts 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import { defineConfig,loadEnv } from 'vite'
  2. import vue from '@vitejs/plugin-vue'
  3. import replace from '@rollup/plugin-replace'
  4. import config from "./src/config.json";
  5. import path from 'path'
  6. // https://vite.dev/config/
  7. export default ({mode, command})=> {
  8. const env = loadEnv(mode, process.cwd(), 'API_') as Record<
  9. 'API_HOST',
  10. string
  11. >
  12. return defineConfig({
  13. // 插件配置,这里使用了Vue插件,以便支持Vue项目的构建
  14. plugins: [
  15. vue(),
  16. /* 替换字符串 */
  17. replace({
  18. preventAssignment: true,
  19. __API__: `${command === 'build' ? env.API_HOST : ''}`,
  20. }),
  21. ],
  22. base: './', // 确保相对路径正确
  23. build: {
  24. outDir: 'dist',
  25. assetsDir: 'assets',
  26. },
  27. /**
  28. * 配置对象,用于定义 CSS 预处理器的选项。
  29. * 通过此配置可以预导入公共样式文件,确保全局样式在所有 SCSS 文件中可用。
  30. */
  31. css: {
  32. preprocessorOptions: {
  33. scss: {
  34. additionalData: `
  35. @use '@/styles/color.scss' as *;
  36. @use '@/styles/index.scss' as *;
  37. ` // 可选:预导入公共样式
  38. }
  39. }
  40. },
  41. // 解析配置,用于配置模块查找和解析行为
  42. resolve: {
  43. // 定义解析文件的扩展名,这允许导入这些文件时省略扩展名
  44. extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue'],
  45. // 路径别名配置,这里定义了'@'符号指向项目的src目录
  46. // 这有助于减少路径引用的复杂性,提高代码的可读性和可维护性
  47. alias: {
  48. '@': path.resolve(__dirname, './src'),
  49. },
  50. },
  51. // 配置服务器相关设置
  52. server: {
  53. // 设置服务器监听的端口
  54. port: 3000,
  55. // 配置代理设置,用于开发环境中代理API请求
  56. proxy: {
  57. // 当请求以'/api'开头时,将其代理到目标服务器
  58. '/api': {
  59. // 目标服务器的地址
  60. target: config.api,
  61. // 允许更改目标服务器的来源
  62. changeOrigin: true
  63. },
  64. },
  65. },
  66. })
  67. }