vite.config.ts 2.1 KB

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