vite.config.ts 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import {resolve} from 'path'
  2. import type {ConfigEnv, UserConfig} from 'vite'
  3. import {loadEnv} from 'vite'
  4. import {createVitePlugins} from './build/vite'
  5. import {exclude, include} from "./build/vite/optimize"
  6. import { visualizer } from 'rollup-plugin-visualizer';
  7. // 当前执行node命令时文件夹的地址(工作目录)
  8. const root = process.cwd()
  9. // 路径查找
  10. function pathResolve(dir: string) {
  11. return resolve(root, '.', dir)
  12. }
  13. // https://vitejs.dev/config/
  14. export default ({command, mode}: ConfigEnv): UserConfig => {
  15. let env = {} as any
  16. const isBuild = command === 'build'
  17. if (!isBuild) {
  18. env = loadEnv((process.argv[3] === '--mode' ? process.argv[4] : process.argv[3]), root)
  19. } else {
  20. env = loadEnv(mode, root)
  21. }
  22. return {
  23. base: env.VITE_BASE_PATH,
  24. root: root,
  25. // 服务端渲染
  26. server: {
  27. port: env.VITE_PORT, // 端口号
  28. host: "0.0.0.0",
  29. open: env.VITE_OPEN === 'true',
  30. // 本地跨域代理. 目前注释的原因:暂时没有用途,server 端已经支持跨域
  31. // proxy: {
  32. // '/admin-api/system': {
  33. // target: env.VITE_BASE_URL,
  34. // ws: false,
  35. // changeOrigin: true,
  36. // // rewrite: (path) => path.replace(new RegExp(`^/admin-api`), ''),
  37. // },
  38. // '/admin-api/laboratory': {
  39. // target: env.VITE_BASE_URL2,
  40. // ws: false,
  41. // changeOrigin: true,
  42. // }
  43. // },
  44. },
  45. // 项目使用的vite插件。 单独提取到build/vite/plugin中管理
  46. plugins: [
  47. createVitePlugins(),
  48. visualizer({ open: true }) // 构建后自动打开分析页面
  49. ],
  50. css: {
  51. preprocessorOptions: {
  52. scss: {
  53. additionalData: '@use "@/styles/variables.scss" as *;',
  54. javascriptEnabled: true,
  55. silenceDeprecations: ["legacy-js-api"], // 参考自 https://stackoverflow.com/questions/78997907/the-legacy-js-api-is-deprecated-and-will-be-removed-in-dart-sass-2-0-0
  56. }
  57. }
  58. },
  59. resolve: {
  60. extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.scss', '.css'],
  61. alias: [
  62. {
  63. find: 'vue-i18n',
  64. replacement: 'vue-i18n/dist/vue-i18n.cjs.js'
  65. },
  66. {
  67. find: /\@\//,
  68. replacement: `${pathResolve('src')}/`
  69. }
  70. ]
  71. },
  72. build: {
  73. minify: 'terser',
  74. outDir: env.VITE_OUT_DIR || 'dist',
  75. sourcemap: env.VITE_SOURCEMAP === 'true' ? 'inline' : false,
  76. // brotliSize: false,
  77. terserOptions: {
  78. compress: {
  79. drop_debugger: env.VITE_DROP_DEBUGGER === 'true',
  80. drop_console: env.VITE_DROP_CONSOLE === 'true',
  81. ecma: 2020, // 使用新版压缩标准
  82. passes: 2 // 减少压缩轮次(默认3)
  83. },
  84. format: {
  85. comments: false // 移除注释
  86. },
  87. maxWorkers: 4 // 启用多线程
  88. },
  89. chunkSizeWarningLimit: 1500, // 提高 chunk 大小警告阈值
  90. rollupOptions: {
  91. // external: [/^@grapecity-software\/.*/],
  92. output: {
  93. manualChunks: {
  94. echarts: ['echarts'], // 将 echarts 单独打包,参考 https://gitee.com/yudaocode/yudao-ui-admin-vue3/issues/IAB1SX 讨论
  95. spreadSheetsDesignerResourcesCn: ['@grapecity-software/spread-sheets-designer-resources-cn'],
  96. spreadSheetsDesignerResourcesEn: ['@grapecity-software/spread-sheets-designer-resources-en'],
  97. spreadSheets: ['@grapecity-software/spread-sheets'],
  98. spreadExcelio: ['@grapecity-software/spread-excelio'],
  99. spreadSheetsBarcode: ['@grapecity-software/spread-sheets-barcode'],
  100. spreadSheetsCharts: ['@grapecity-software/spread-sheets-charts'],
  101. spreadSheetsDesigner: ['@grapecity-software/spread-sheets-designer'],
  102. spreadSheetsIo: ['@grapecity-software/spread-sheets-io'],
  103. spreadSheetsLanguagepackages: ['@grapecity-software/spread-sheets-languagepackages'],
  104. spreadSheetsPdf: ['@grapecity-software/spread-sheets-pdf'],
  105. spreadSheetsPivotAddon: ['@grapecity-software/spread-sheets-pivot-addon'],
  106. spreadSheetsPrint: ['@grapecity-software/spread-sheets-print'],
  107. spreadSheetsShapes: ['@grapecity-software/spread-sheets-shapes'],
  108. spreadSheetsTablesheet: ['@grapecity-software/spread-sheets-tablesheet'],
  109. spreadSheetsDesignerVue: ['@grapecity-software/spread-sheets-designer-vue'],
  110. }
  111. }
  112. },
  113. },
  114. optimizeDeps: {include, exclude}
  115. }
  116. }