import {resolve} from 'path' import type {ConfigEnv, UserConfig} from 'vite' import {loadEnv} from 'vite' import {createVitePlugins} from './build/vite' import {exclude, include} from "./build/vite/optimize" // 当前执行node命令时文件夹的地址(工作目录) const root = process.cwd() // 路径查找 function pathResolve(dir: string) { return resolve(root, '.', dir) } // https://vitejs.dev/config/ export default ({command, mode}: ConfigEnv): UserConfig => { let env = {} as any const isBuild = command === 'build' if (!isBuild) { env = loadEnv((process.argv[3] === '--mode' ? process.argv[4] : process.argv[3]), root) } else { env = loadEnv(mode, root) } return { base: env.VITE_BASE_PATH, root: root, // 服务端渲染 server: { port: env.VITE_PORT, // 端口号 host: "0.0.0.0", open: env.VITE_OPEN === 'true', // 本地跨域代理. 目前注释的原因:暂时没有用途,server 端已经支持跨域 // proxy: { // ['/admin-api']: { // target: env.VITE_BASE_URL, // ws: false, // changeOrigin: true, // rewrite: (path) => path.replace(new RegExp(`^/admin-api`), ''), // }, // }, }, // 项目使用的vite插件。 单独提取到build/vite/plugin中管理 plugins: createVitePlugins(), css: { preprocessorOptions: { scss: { additionalData: '@use "@/styles/variables.scss" as *;', javascriptEnabled: true, 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 } } }, resolve: { extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.scss', '.css'], alias: [ { find: 'vue-i18n', replacement: 'vue-i18n/dist/vue-i18n.cjs.js' }, { find: /\@\//, replacement: `${pathResolve('src')}/` } ] }, build: { minify: 'esbuild', // 使用 esbuild 代替 terser,更快且内存占用更少 outDir: env.VITE_OUT_DIR || 'dist', sourcemap: env.VITE_SOURCEMAP === 'true' ? 'inline' : false, // brotliSize: false, rollupOptions: { output: { manualChunks: { echarts: ['echarts'], // 将 echarts 单独打包,参考 https://gitee.com/yudaocode/yudao-ui-admin-vue3/issues/IAB1SX 讨论 'form-create': ['@form-create/element-ui'], // 参考 https://github.com/yudaocode/yudao-ui-admin-vue3/issues/148 讨论 'form-designer': ['@form-create/designer'], }, chunkFileNames: 'js/[name]-[hash].js', entryFileNames: 'js/[name]-[hash].js', assetFileNames: '[ext]/[name]-[hash].[ext]' }, // 增加最大 chunk 大小限制 onwarn(warning, warn) { if (warning.code === 'CIRCULAR_DEPENDENCY') return warn(warning) } }, chunkSizeWarningLimit: 2000 // 增加 chunk 大小警告限制 }, optimizeDeps: {include, exclude} } }