vite.config.js 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import { defineConfig, loadEnv } 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 { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
  8. import viteCompression from 'vite-plugin-compression'
  9. // eslint
  10. import eslintPlugin from 'vite-plugin-eslint'
  11. // https://vitejs.dev/config/
  12. export default defineConfig(({ command })=> {
  13. return {
  14. plugins: [
  15. vue(),
  16. createSvgIconsPlugin({
  17. iconDirs: [path.resolve(process.cwd(), 'src/icons/svg')],
  18. symbolId: 'icon-[dir]-[name]'
  19. }),
  20. // 自动引入内容
  21. AutoImport({
  22. imports: [
  23. 'vue',
  24. 'vue-router'
  25. ],
  26. dirs: [
  27. 'src/hooks/**',
  28. 'src/stores/**',
  29. 'src/utils/**'
  30. ],
  31. resolvers: command === 'build' ? [ElementPlusResolver()] : [],
  32. dts: 'src/auto-import/imports.d.ts',
  33. eslintrc: {
  34. enabled: false
  35. }
  36. }),
  37. // 自动引入组件
  38. Components({
  39. dirs: [
  40. 'src/components'
  41. ],
  42. resolvers: command === 'build' ? [ElementPlusResolver()] : [],
  43. dts: 'src/auto-import/components.d.ts'
  44. }),
  45. // 对大于 1k 的文件进行压缩
  46. viteCompression({
  47. threshold: 1000,
  48. })
  49. ].concat(
  50. // eslint
  51. command !== 'build' ? [eslintPlugin({ include: ['src/**/*.js', 'src/**/*.vue', 'src/*.js', 'src/*.vue'] })] : []
  52. ),
  53. server: {
  54. host: true,
  55. port: 9527,
  56. open: true
  57. },
  58. resolve: {
  59. alias: {
  60. '@': path.resolve(__dirname, 'src'),
  61. 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js'
  62. }
  63. },
  64. build: {
  65. base: './',
  66. rollupOptions: {
  67. // 静态资源分类打包
  68. output: {
  69. chunkFileNames: 'static/js/[name]-[hash].js',
  70. entryFileNames: 'static/js/[name]-[hash].js',
  71. assetFileNames: 'static/[ext]/[name]-[hash].[ext]',
  72. // 静态资源分拆打包
  73. manualChunks (id) {
  74. if (id.includes('node_modules')) {
  75. if (id.toString().indexOf('.pnpm/') !== -1) {
  76. return id.toString().split('.pnpm/')[1].split('/')[0].toString();
  77. } else if (id.toString().indexOf('node_modules/') !== -1) {
  78. return id.toString().split('node_modules/')[1].split('/')[0].toString();
  79. }
  80. }
  81. }
  82. }
  83. },
  84. sourcemap: false,
  85. target: 'es2015',
  86. reportCompressedSize: false
  87. }
  88. }
  89. })