vite.config.ts 2.7 KB
Newer Older
1 2
import type { UserConfig } from 'vite';

陈文彬 已提交
3 4
import { resolve } from 'path';

5 6 7 8 9
import { modifyVars } from './build/config/lessModifyVars';
import { createProxy } from './build/vite/proxy';
import globbyTransform from './build/vite/plugin/context/transform';

import { isDevFn, loadEnv } from './build/utils';
陈文彬 已提交
10

11
import { createRollupPlugin, createVitePlugins } from './build/vite/plugin';
12 13

const pkg = require('./package.json');
陈文彬 已提交
14

15 16
const viteEnv = loadEnv();

17 18 19 20
const {
  VITE_PORT,
  VITE_PUBLIC_PATH,
  VITE_PROXY,
V
vben 已提交
21
  VITE_DROP_CONSOLE,
22
  // VITE_USE_CDN,
23
} = viteEnv;
陈文彬 已提交
24 25 26 27

function pathResolve(dir: string) {
  return resolve(__dirname, '.', dir);
}
B
bin 已提交
28

陈文彬 已提交
29
const viteConfig: UserConfig = {
V
vben 已提交
30 31 32 33 34
  /**
   * Entry. Use this to specify a js entry file in use cases where an
   * `index.html` does not exist (e.g. serving vite assets from a different host)
   * @default 'index.html'
   */
V
vben 已提交
35 36
  // TODO build error
  // entry: './public/index.html',
B
bin 已提交
37 38 39 40 41
  /**
   * 端口号
   * @default '3000'
   */
  port: VITE_PORT,
陈文彬 已提交
42 43 44 45 46 47
  /**
   * 服务地址
   * @default 'localhost'
   */
  hostname: 'localhost',
  /**
陈文彬 已提交
48
   * 运行自动打开浏览器·
陈文彬 已提交
49 50 51 52 53 54 55 56
   * @default 'false'
   */
  open: false,
  /**
   * 压缩代码
   *  boolean | 'terser' | 'esbuild'
   * @default 'terser'
   */
V
vben 已提交
57
  minify: isDevFn() ? 'esbuild' : 'terser',
陈文彬 已提交
58
  /**
B
bin 已提交
59
   * 基本公共路径
陈文彬 已提交
60 61
   * @default '/'
   */
B
bin 已提交
62
  base: VITE_PUBLIC_PATH,
陈文彬 已提交
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84

  /**
   * 打包输入路径
   * @default 'dist'
   */
  outDir: 'dist',
  /**
   * @default 'false'
   */
  sourcemap: false,
  /**
   * 资源输出路径
   * @default '_assets'
   */
  assetsDir: '_assets',
  /**
   * 静态资源小于该大小将会内联,默认4096kb
   * @default '4096'
   */
  assetsInlineLimit: 4096,
  /**
   * esbuild转换目标。
V
vben 已提交
85
   * @default 'es2020'
陈文彬 已提交
86
   */
V
vben 已提交
87
  esbuildTarget: 'es2020',
B
bin 已提交
88
  silent: false,
陈文彬 已提交
89 90 91 92
  // 别名
  alias: {
    '/@/': pathResolve('src'),
  },
V
vben 已提交
93
  // terser配置
V
vben 已提交
94
  terserOptions: {
V
vben 已提交
95 96 97 98 99
    compress: {
      // 是否删除console
      drop_console: VITE_DROP_CONSOLE,
    },
  },
100 101 102
  define: {
    __VERSION__: pkg.version,
  },
陈文彬 已提交
103 104 105 106 107 108 109
  // css预处理
  cssPreprocessOptions: {
    less: {
      modifyVars: modifyVars,
      javascriptEnabled: true,
    },
  },
V
vben 已提交
110
  // 会使用 rollup 对 包重新编译,将编译成符合 esm 模块规范的新的包放入 node_modules/.vite_opt_cache
陈文彬 已提交
111
  optimizeDeps: {
112 113 114 115 116 117 118
    include: [
      'echarts',
      'echarts/map/js/china',
      'ant-design-vue/es/locale/zh_CN',
      '@ant-design/icons-vue',
      'moment/locale/zh-cn',
    ],
陈文彬 已提交
119
  },
V
vben 已提交
120

陈文彬 已提交
121
  // 本地跨域代理
B
bin 已提交
122
  proxy: createProxy(VITE_PROXY),
123
  plugins: createVitePlugins(viteEnv),
陈文彬 已提交
124
  rollupInputOptions: {
125 126
    // TODO
    // external: VITE_USE_CDN ? externals : [],
127
    plugins: createRollupPlugin(),
陈文彬 已提交
128 129 130
  },
};

V
vben 已提交
131 132 133 134
export default {
  ...viteConfig,
  transforms: [globbyTransform(viteConfig)],
} as UserConfig;