vite.config.ts 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /// <reference types="vitest" />
  2. import { type ConfigEnv, type UserConfigExport, loadEnv } from "vite"
  3. import path, { resolve } from "path"
  4. import vue from "@vitejs/plugin-vue"
  5. import vueJsx from "@vitejs/plugin-vue-jsx"
  6. import { createSvgIconsPlugin } from "vite-plugin-svg-icons"
  7. import svgLoader from "vite-svg-loader"
  8. import UnoCSS from "unocss/vite"
  9. /** 配置项文档:https://cn.vitejs.dev/config */
  10. export default (configEnv: ConfigEnv): UserConfigExport => {
  11. const viteEnv = loadEnv(configEnv.mode, process.cwd()) as ImportMetaEnv
  12. const { VITE_PUBLIC_PATH } = viteEnv
  13. return {
  14. /** 打包时根据实际情况修改 base */
  15. base: VITE_PUBLIC_PATH,
  16. resolve: {
  17. alias: {
  18. /** @ 符号指向 src 目录 */
  19. "@": resolve(__dirname, "./src")
  20. }
  21. },
  22. server: {
  23. /** 设置 host: true 才可以使用 Network 的形式,以 IP 访问项目 */
  24. host: true, // host: "0.0.0.0"
  25. /** 端口号 */
  26. port: 3333,
  27. /** 是否自动打开浏览器 */
  28. open: false,
  29. /** 跨域设置允许 */
  30. cors: true,
  31. /** 端口被占用时,是否直接退出 */
  32. strictPort: false,
  33. /** 接口代理 */
  34. proxy: {
  35. "/api/v1": {
  36. target: "https://mock.mengxuegu.com/mock/63218b5fb4c53348ed2bc212",
  37. ws: true,
  38. /** 是否允许跨域 */
  39. changeOrigin: true
  40. }
  41. },
  42. /** 预热常用文件,提高初始页面加载速度 */
  43. warmup: {
  44. clientFiles: ["./src/layouts/**/*.vue"]
  45. }
  46. },
  47. build: {
  48. /** 单个 chunk 文件的大小超过 2048KB 时发出警告 */
  49. chunkSizeWarningLimit: 2048,
  50. /** 禁用 gzip 压缩大小报告 */
  51. reportCompressedSize: false,
  52. /** 打包后静态资源目录 */
  53. assetsDir: "static",
  54. rollupOptions: {
  55. output: {
  56. /**
  57. * 分块策略
  58. * 1. 注意这些包名必须存在,否则打包会报错
  59. * 2. 如果你不想自定义 chunk 分割策略,可以直接移除这段配置
  60. */
  61. manualChunks: {
  62. vue: ["vue", "vue-router", "pinia"],
  63. element: ["element-plus", "@element-plus/icons-vue"],
  64. vxe: ["vxe-table", "vxe-table-plugin-element", "xe-utils"]
  65. }
  66. }
  67. }
  68. },
  69. /** 混淆器 */
  70. esbuild: {
  71. /** 打包时移除 console.log */
  72. pure: ["console.log"],
  73. /** 打包时移除 debugger */
  74. drop: ["debugger"],
  75. /** 打包时移除所有注释 */
  76. legalComments: "none"
  77. },
  78. /** Vite 插件 */
  79. plugins: [
  80. vue(),
  81. vueJsx(),
  82. /** 将 SVG 静态图转化为 Vue 组件 */
  83. svgLoader({ defaultImport: "url" }),
  84. /** SVG */
  85. createSvgIconsPlugin({
  86. iconDirs: [path.resolve(process.cwd(), "src/icons/svg")],
  87. symbolId: "icon-[dir]-[name]"
  88. }),
  89. /** UnoCSS */
  90. UnoCSS()
  91. ],
  92. /** Vitest 单元测试配置:https://cn.vitest.dev/config */
  93. test: {
  94. include: ["tests/**/*.test.ts"],
  95. environment: "jsdom"
  96. }
  97. }
  98. }