vite.config.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. import { defineConfig } from 'vite'
  2. import vue from '@vitejs/plugin-vue'
  3. import path from 'path'
  4. import AutoImport from 'unplugin-auto-import/vite'
  5. import Components from 'unplugin-vue-components/vite'
  6. import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
  7. import ElementPlus from 'unplugin-element-plus/vite'
  8. import viteCompression from 'vite-plugin-compression'
  9. // eslint
  10. import eslintPlugin from 'vite-plugin-eslint'
  11. import Icons from 'unplugin-icons/vite'
  12. import IconsResolver from 'unplugin-icons/resolver'
  13. import legacy from '@vitejs/plugin-legacy'
  14. // https://vitejs.dev/config/
  15. export default defineConfig({
  16. plugins: [
  17. legacy({
  18. // 兼容浏览器列表
  19. targets: ['Android >= 7', 'chrome >= 51', 'firefox >= 54', 'ios >= 10']
  20. }),
  21. vue(),
  22. AutoImport({
  23. imports: [
  24. 'vue',
  25. 'vue-router'
  26. ],
  27. dirs: [
  28. 'src/utils/**',
  29. 'src/stores/**'
  30. ],
  31. dts: 'src/auto-import/imports.d.ts',
  32. eslintrc: {
  33. enabled: true
  34. },
  35. resolvers: [
  36. ElementPlusResolver(),
  37. // 自动导入图标组件
  38. IconsResolver({
  39. prefix: 'Icon'
  40. })
  41. ]
  42. }),
  43. Components({
  44. dirs: [
  45. 'src/components'
  46. ],
  47. dts: 'src/auto-import/components.d.ts',
  48. resolvers: [
  49. ElementPlusResolver(),
  50. // 自动注册图标组件
  51. IconsResolver({
  52. enabledCollections: ['ep']
  53. })
  54. ]
  55. }),
  56. Icons({
  57. autoInstall: true
  58. }),
  59. // eslint
  60. eslintPlugin({
  61. include: ['src/**/*.js', 'src/**/*.vue', 'src/*.js', 'src/*.vue']
  62. }),
  63. // 对大于 1k 的文件进行压缩
  64. viteCompression({
  65. threshold: 1000
  66. }),
  67. ElementPlus()
  68. ],
  69. resolve: {
  70. alias: {
  71. '@': path.resolve(__dirname, 'src'),
  72. 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js'
  73. }
  74. },
  75. server: {
  76. host: '0.0.0.0',
  77. port: 3344,
  78. open: true
  79. },
  80. build: {
  81. base: './',
  82. rollupOptions: {
  83. // 静态资源分类打包
  84. output: {
  85. chunkFileNames: 'static/js/[name]-[hash].js',
  86. entryFileNames: 'static/js/[name]-[hash].js',
  87. assetFileNames: 'static/[ext]/[name]-[hash].[ext]',
  88. // 静态资源分拆打包
  89. manualChunks (id) {
  90. if (id.includes('node_modules')) {
  91. if (id.toString().indexOf('.pnpm/') !== -1) {
  92. return id.toString().split('.pnpm/')[1].split('/')[0].toString()
  93. } else if (id.toString().indexOf('node_modules/') !== -1) {
  94. return id.toString().split('node_modules/')[1].split('/')[0].toString()
  95. }
  96. }
  97. }
  98. }
  99. },
  100. sourcemap: false,
  101. minify: 'terser',
  102. reportCompressedSize: false
  103. }
  104. })