vite.config.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. import vue from '@vitejs/plugin-vue';
  2. import viteCompression from 'vite-plugin-compression'
  3. import { resolve } from 'path';
  4. import { defineConfig, loadEnv, ConfigEnv } from 'vite';
  5. const pathResolve = (dir: string): any => {
  6. return resolve(__dirname, '.', dir);
  7. };
  8. const alias: Record<string, string> = {
  9. '/@': pathResolve('./src/'),
  10. 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js',
  11. };
  12. const viteConfig = defineConfig((mode: ConfigEnv) => {
  13. const env = loadEnv(mode.mode, process.cwd());
  14. return {
  15. plugins: [
  16. vue(),
  17. viteCompression({
  18. threshold: 1024 * 20, // 对大于 20k 的文件进行压缩
  19. // filter: /\.(js|css|json|txt|html|ico|svg)(\?.*)?$/i, // 需要压缩的文件
  20. algorithm: 'gzip', // 压缩方式
  21. ext: 'gz', // 后缀名
  22. deleteOriginFile: false, // 压缩后是否删除压缩源文件
  23. })
  24. ],
  25. root: process.cwd(),
  26. resolve: { alias },
  27. base: mode.command === 'serve' ? './' : env.VITE_PUBLIC_PATH,
  28. optimizeDeps: {
  29. include: ['element-plus/lib/locale/lang/zh-cn', 'element-plus/lib/locale/lang/en', 'element-plus/lib/locale/lang/zh-tw'],
  30. },
  31. server: {
  32. host: '0.0.0.0',
  33. port: env.VITE_PORT as unknown as number,
  34. open: true,
  35. hmr: true,
  36. proxy: {
  37. [env.VITE_API_SUFFIX_URL]: {
  38. target: env.VITE_SERVER_ORIGIN,
  39. ws: true,
  40. changeOrigin: true,
  41. // rewrite: (path) => path.replace(/^\/api/, ''),
  42. },
  43. [env.VITE_SERVER_ORIGIN + env.VITE_API_SUFFIX_URL]: {
  44. target: env.VITE_SERVER_ORIGIN,
  45. ws: true,
  46. changeOrigin: true,
  47. rewrite: (path) => path.replace(env.VITE_SERVER_ORIGIN, ''),
  48. },
  49. },
  50. },
  51. build: {
  52. outDir: 'sagoo-iot',
  53. sourcemap: false,
  54. cssCodeSplit: false,
  55. chunkSizeWarningLimit: 1500,
  56. rollupOptions: {
  57. output: {
  58. entryFileNames: `assets/[name].${new Date().getTime()}.js`,
  59. chunkFileNames: `assets/[name].${new Date().getTime()}.js`,
  60. assetFileNames: `assets/[name].${new Date().getTime()}.[ext]`,
  61. compact: true,
  62. manualChunks: {
  63. vue: ['vue', 'vue-router', 'vuex'],
  64. echarts: ['echarts'],
  65. },
  66. },
  67. },
  68. },
  69. css: {
  70. postcss: {
  71. plugins: [
  72. {
  73. postcssPlugin: 'internal:charset-removal',
  74. AtRule: {
  75. charset: (atRule) => {
  76. if (atRule.name === 'charset') {
  77. atRule.remove();
  78. }
  79. },
  80. },
  81. },
  82. ],
  83. },
  84. },
  85. define: {
  86. __VUE_I18N_LEGACY_API__: JSON.stringify(false),
  87. __VUE_I18N_FULL_INSTALL__: JSON.stringify(false),
  88. __INTLIFY_PROD_DEVTOOLS__: JSON.stringify(false),
  89. },
  90. };
  91. });
  92. export default viteConfig;