vite.config.ts 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. import { resolve } from 'path'
  2. import { loadEnv } from 'vite'
  3. import type { UserConfig, ConfigEnv } from 'vite'
  4. import Vue from '@vitejs/plugin-vue'
  5. import WindiCSS from 'vite-plugin-windicss'
  6. import VueJsx from '@vitejs/plugin-vue-jsx'
  7. import EslintPlugin from 'vite-plugin-eslint'
  8. import VueI18n from '@intlify/vite-plugin-vue-i18n'
  9. import { createStyleImportPlugin, ElementPlusResolve } from 'vite-plugin-style-import'
  10. import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
  11. import PurgeIcons from 'vite-plugin-purge-icons'
  12. import { viteMockServe } from 'vite-plugin-mock'
  13. import VueSetupExtend from 'vite-plugin-vue-setup-extend'
  14. // https://vitejs.dev/config/
  15. const root = process.cwd()
  16. function pathResolve(dir: string) {
  17. return resolve(root, '.', dir)
  18. }
  19. // https://vitejs.dev/config/
  20. export default ({ command, mode }: ConfigEnv): UserConfig => {
  21. let env = null
  22. const isBuild = command === 'build'
  23. if (!isBuild) {
  24. env = loadEnv((process.argv[3] === '--mode' ? process.argv[4] : process.argv[3]), root)
  25. } else {
  26. env = loadEnv(mode, root)
  27. }
  28. return {
  29. base: env.VITE_BASE_PATH,
  30. plugins: [
  31. Vue(),
  32. VueJsx(),
  33. WindiCSS(),
  34. createStyleImportPlugin({
  35. resolves: [ElementPlusResolve()],
  36. libs: [{
  37. libraryName: 'element-plus',
  38. esModule: true,
  39. resolveStyle: (name) => {
  40. return `element-plus/es/components/${name.substring(3)}/style/css`
  41. }
  42. }]
  43. }),
  44. EslintPlugin({
  45. cache: false,
  46. include: ['src/**/*.vue', 'src/**/*.ts', 'src/**/*.tsx'] // 检查的文件
  47. }),
  48. VueI18n({
  49. runtimeOnly: true,
  50. compositionOnly: true,
  51. include: [resolve(__dirname, 'src/locales/**')]
  52. }),
  53. createSvgIconsPlugin({
  54. iconDirs: [pathResolve('src/assets/svgs')],
  55. symbolId: 'icon-[dir]-[name]',
  56. svgoOptions: true
  57. }),
  58. PurgeIcons(),
  59. viteMockServe({
  60. ignore: /^\_/,
  61. mockPath: 'mock',
  62. localEnabled: !isBuild,
  63. prodEnabled: isBuild,
  64. injectCode: `
  65. import { setupProdMockServer } from '../mock/_createProductionServer'
  66. setupProdMockServer()
  67. `
  68. }),
  69. VueSetupExtend()
  70. ],
  71. css: {
  72. preprocessorOptions: {
  73. less: {
  74. additionalData: '@import "./src/styles/variables.module.less";',
  75. javascriptEnabled: true
  76. }
  77. }
  78. },
  79. resolve: {
  80. extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.less', '.css'],
  81. alias: [
  82. {
  83. find: 'vue-i18n',
  84. replacement: 'vue-i18n/dist/vue-i18n.cjs.js'
  85. },
  86. {
  87. find: /\@\//,
  88. replacement: `${pathResolve('src')}/`
  89. }
  90. ]
  91. },
  92. build: {
  93. minify: 'terser',
  94. outDir: env.VITE_OUT_DIR || 'dist',
  95. sourcemap: env.VITE_SOURCEMAP === 'true' ? 'inline' : false,
  96. brotliSize: false,
  97. terserOptions: {
  98. compress: {
  99. drop_debugger: env.VITE_DROP_DEBUGGER === 'true',
  100. drop_console: env.VITE_DROP_CONSOLE === 'true'
  101. }
  102. }
  103. },
  104. server: {
  105. proxy: {
  106. // 选项写法
  107. // '/api': {
  108. // target: 'http://localhost:3000',
  109. // changeOrigin: true,
  110. // rewrite: path => path.replace(/^\/api/, '')
  111. // }
  112. },
  113. hmr: {
  114. overlay: false
  115. },
  116. host: '0.0.0.0'
  117. },
  118. optimizeDeps: {
  119. include: [
  120. 'vue',
  121. 'vue-router',
  122. 'vue-types',
  123. 'element-plus/lib/locale/lang/zh-cn',
  124. 'element-plus/lib/locale/lang/en',
  125. '@iconify/iconify',
  126. '@vueuse/core',
  127. 'axios',
  128. 'qs',
  129. 'echarts',
  130. 'echarts-wordcloud',
  131. 'intro.js',
  132. 'qrcode',
  133. '@wangeditor/editor',
  134. '@wangeditor/editor-for-vue'
  135. ]
  136. }
  137. }
  138. }