vite.config.ts 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import { resolve } from 'path'
  2. import { loadEnv } from 'vite'
  3. import type { UserConfig, ConfigEnv } from 'vite'
  4. import { createVitePlugins } from './build/vite'
  5. import { include, exclude } from "./build/vite/optimize"
  6. // 当前执行node命令时文件夹的地址(工作目录)
  7. const root = process.cwd()
  8. // 路径查找
  9. function pathResolve(dir: string) {
  10. return resolve(root, '.', dir)
  11. }
  12. // https://vitejs.dev/config/
  13. export default ({ command, mode }: ConfigEnv): UserConfig => {
  14. let env = {} as any
  15. const isBuild = command === 'build'
  16. if (!isBuild) {
  17. env = loadEnv((process.argv[3] === '--mode' ? process.argv[4] : process.argv[3]), root)
  18. } else {
  19. env = loadEnv(mode, root)
  20. }
  21. return {
  22. base: env.VITE_BASE_PATH,
  23. root: root,
  24. // 服务端渲染
  25. server: {
  26. // 是否开启 https
  27. https: false,
  28. // 端口号
  29. port: env.VITE_PORT,
  30. host: "0.0.0.0",
  31. open: env.VITE_OPEN === 'true',
  32. // 本地跨域代理. 目前注释的原因:暂时没有用途,server 端已经支持跨域
  33. /* proxy: {
  34. // [process.env.VITE_API_URL]: {
  35. // target: process.env.VITE_BASE_URL,
  36. // ws: false,
  37. // changeOrigin: true,
  38. // rewrite: (path) => path.replace(new RegExp(`^`+process.env.VITE_API_URL), process.env.VITE_API_BASEPATH),
  39. // },
  40. "^/admin-api": {
  41. target: env.VITE_BASE_URL, // 真实接口地址, 后端给的基地址
  42. changeOrigin: true, // 允许跨域
  43. rewrite: (path) => path.replace(/^\/admin-api/, env.VITE_API_BASEPATH), // 将ccc替换为空
  44. },
  45. },*/
  46. },
  47. // 项目使用的vite插件。 单独提取到build/vite/plugin中管理
  48. plugins: createVitePlugins(),
  49. css: {
  50. preprocessorOptions: {
  51. scss: {
  52. additionalData: '@import "./src/styles/variables.scss";',
  53. javascriptEnabled: true
  54. }
  55. }
  56. },
  57. resolve: {
  58. extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.scss', '.css'],
  59. alias: [
  60. {
  61. find: 'vue-i18n',
  62. replacement: 'vue-i18n/dist/vue-i18n.cjs.js'
  63. },
  64. {
  65. find: /\@\//,
  66. replacement: `${pathResolve('src')}/`
  67. }
  68. ]
  69. },
  70. build: {
  71. minify: 'terser',
  72. outDir: env.VITE_OUT_DIR || 'dist',
  73. sourcemap: env.VITE_SOURCEMAP === 'true' ? 'inline' : false,
  74. // brotliSize: false,
  75. terserOptions: {
  76. compress: {
  77. drop_debugger: env.VITE_DROP_DEBUGGER === 'true',
  78. drop_console: env.VITE_DROP_CONSOLE === 'true'
  79. }
  80. }
  81. },
  82. optimizeDeps: { include, exclude }
  83. }
  84. }