123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- import { resolve } from 'path';
- import type { UserConfig, Plugin as VitePlugin } from 'vite';
- import type { Plugin } from 'rollup';
- import visualizer from 'rollup-plugin-visualizer';
- import { modifyVars } from './build/config/glob/lessModifyVars';
- import { setupBasicEnv } from './build/config/vite/env';
- import { createProxy } from './build/config/vite/proxy';
- import { createMockServer } from 'vite-plugin-mock';
- import PurgeIcons from 'vite-plugin-purge-icons';
- import { isDevFn, isReportMode, isProdFn, loadEnv } from './build/utils';
- setupBasicEnv();
- const { VITE_USE_MOCK } = loadEnv();
- function pathResolve(dir: string) {
- return resolve(__dirname, '.', dir);
- }
- const rollupPlugins: Plugin[] = [];
- const vitePlugins: VitePlugin[] = [];
- (() => {
- if (isReportMode() && isProdFn()) {
- // report
- rollupPlugins.push(
- visualizer({ filename: './node_modules/.cache/stats.html', open: true }) as Plugin
- );
- }
- if (isDevFn() && VITE_USE_MOCK === 'true') {
- // open mock
- vitePlugins.push(
- createMockServer({
- ignore: /^\_/,
- mockPath: 'mock',
- })
- );
- }
- })();
- const viteConfig: UserConfig = {
- silent: false,
- /**
- * 服务地址
- * @default 'localhost'
- */
- hostname: 'localhost',
- /**
- * 端口号
- * @default '3000'
- */
- port: 3100,
- /**
- * 运行自动打开浏览器·
- * @default 'false'
- */
- open: false,
- /**
- * 压缩代码
- * boolean | 'terser' | 'esbuild'
- * @default 'terser'
- */
- minify: isDevFn() ? false : 'terser',
- /**
- * 在生产中投放时提供基本公共路径
- * @default '/'
- */
- base: isDevFn() ? '/' : './',
- /**
- * 打包输入路径
- * @default 'dist'
- */
- outDir: 'dist',
- /**
- * @default 'false'
- */
- sourcemap: false,
- /**
- * 资源输出路径
- * @default '_assets'
- */
- assetsDir: '_assets',
- /**
- * 静态资源小于该大小将会内联,默认4096kb
- * @default '4096'
- */
- assetsInlineLimit: 4096,
- /**
- * esbuild转换目标。
- * @default 'es2019'
- */
- esbuildTarget: 'es2019',
- // 别名
- alias: {
- '/@/': pathResolve('src'),
- },
- // define: {
- // __ENV__: 'value',
- // },
- // css预处理
- cssPreprocessOptions: {
- less: {
- modifyVars: modifyVars,
- javascriptEnabled: true,
- },
- },
- // 配置Dep优化行为
- // 会使用 rollup 对 包重新编译,将编译成符合 esm 模块规范的新的包放入 node_modules 下的 .
- optimizeDeps: {
- include: ['ant-design-vue/es/locale/zh_CN', '@ant-design/icons-vue', 'moment/locale/zh-cn'],
- },
- // 本地跨域代理
- proxy: createProxy([['/api', 'http://localhost:3000']]),
- plugins: [PurgeIcons(), ...vitePlugins],
- rollupOutputOptions: {},
- rollupInputOptions: {
- plugins: rollupPlugins,
- },
- };
- export default viteConfig;
|