vite.config.js 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import { defineConfig } from 'vite'
  2. import vue from '@vitejs/plugin-vue'
  3. import { resolve } from 'path'
  4. import UnoCSS from 'unocss/vite'
  5. import config from './src/config'
  6. // https://vitejs.dev/config/
  7. export default defineConfig({
  8. resolve: {
  9. alias: {
  10. '~src': `${resolve(__dirname, './src')}`,
  11. '~com': `${resolve(__dirname, './src/components')}`,
  12. '~api': resolve(__dirname, './src/api/modules'),
  13. },
  14. },
  15. plugins: [
  16. vue(),
  17. UnoCSS(),
  18. ],
  19. build: {
  20. rollupOptions: {
  21. output: {
  22. manualChunks(id) {
  23. let libStr = '@vue,element-plus,echarts,vue-router,pinia,js-fast-way'
  24. const libs = libStr.split(',')
  25. if (id.includes('node_modules')) {
  26. const arr = id.toString().split('node_modules/')[1].split('/')
  27. if (libs.indexOf(arr[0]) !== -1) {
  28. return '_' + arr[0]
  29. } else {
  30. return '__vendor'
  31. }
  32. }
  33. },
  34. chunkFileNames: 'static/js1/[name]-[hash].js',
  35. entryFileNames: 'static/js2/[name]-[hash].js',
  36. assetFileNames: 'static/[ext]/[name]-[hash].[ext]',
  37. },
  38. brotliSize: false, // 不统计
  39. target: 'esnext',
  40. minify: 'esbuild', // 混淆器,terser构建后文件体积更小
  41. },
  42. },
  43. server: {
  44. ...config.vite,
  45. proxy: {
  46. '/api': {
  47. ws: true,
  48. changeOrigin: true,
  49. target: config.target,
  50. rewrite: (path) => path.replace(new RegExp('^/api'), '/'),
  51. },
  52. },
  53. },
  54. })