123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- import { defineConfig, loadEnv, ConfigEnv, UserConfig } from 'vite'
- import { resolve } from 'path'
- import { wrapperEnv } from './build/getEnv'
- import { createProxy } from './build/proxy'
- import { createVitePlugins } from './build/plugins'
- import pkg from './package.json'
- import dayjs from 'dayjs'
- const { dependencies, devDependencies, name, version } = pkg
- const __APP_INFO__ = {
- pkg: { dependencies, devDependencies, name, version },
- lastBuildTime: dayjs().format('YYYY-MM-DD HH:mm:ss')
- }
- // @see: https://vitejs.dev/config/
- export default defineConfig(({ mode }: ConfigEnv): UserConfig => {
- const root = process.cwd()
- const env = loadEnv(mode, root)
- const viteEnv = wrapperEnv(env)
- return {
- base: viteEnv.VITE_PUBLIC_PATH,
- root,
- resolve: {
- alias: {
- '~': resolve(__dirname, './'),
- '@': resolve(__dirname, './src'),
- 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js'
- },
- extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']
- },
- define: {
- __APP_INFO__: JSON.stringify(__APP_INFO__)
- },
- css: {
- preprocessorOptions: {
- scss: {
- javascriptEnabled: true,
- additionalData: `@import "@/styles/var.scss";`
- }
- },
- postcss: {
- plugins: [
- {
- postcssPlugin: 'internal:charset-removal',
- AtRule: {
- charset: atRule => {
- if (atRule.name === 'charset') {
- atRule.remove()
- }
- }
- }
- }
- ]
- }
- },
- server: {
- host: '0.0.0.0',
- port: viteEnv.VITE_PORT,
- open: viteEnv.VITE_OPEN,
- cors: true,
- // Load proxy configuration from .env.development
- proxy: createProxy(viteEnv.VITE_PROXY)
- },
- plugins: createVitePlugins(viteEnv),
- esbuild: {
- pure: viteEnv.VITE_DROP_CONSOLE ? ['console.log', 'debugger'] : []
- },
- build: {
- outDir: 'dist',
- minify: 'esbuild',
- // esbuild 打包更快,但是不能去除 console.log,terser打包慢,但能去除 console.log
- // minify: "terser",
- // terserOptions: {
- // compress: {
- // drop_console: viteEnv.VITE_DROP_CONSOLE,
- // drop_debugger: true
- // }
- // },
- sourcemap: false,
- // 禁用 gzip 压缩大小报告,可略微减少打包时间
- reportCompressedSize: false,
- // 规定触发警告的 chunk 大小
- chunkSizeWarningLimit: 2000,
- rollupOptions: {
- output: {
- // Static resource classification and packaging
- chunkFileNames: 'assets/js/[name]-[hash].js',
- entryFileNames: 'assets/js/[name]-[hash].js',
- assetFileNames: 'assets/[ext]/[name]-[hash].[ext]'
- }
- }
- },
- // 预编译
- optimizeDeps: {
- include: [
- 'vue',
- 'vue-router',
- 'pinia',
- 'axios',
- '@vueuse/core',
- 'path-to-regexp',
- 'echarts',
- 'vue-i18n',
- 'element-plus/es/components/form/style/css',
- 'element-plus/es/components/form-item/style/css',
- 'element-plus/es/components/button/style/css',
- 'element-plus/es/components/input/style/css',
- 'element-plus/es/components/input-number/style/css',
- 'element-plus/es/components/switch/style/css',
- 'element-plus/es/components/upload/style/css',
- 'element-plus/es/components/menu/style/css',
- 'element-plus/es/components/col/style/css',
- 'element-plus/es/components/icon/style/css',
- 'element-plus/es/components/row/style/css',
- 'element-plus/es/components/tag/style/css',
- 'element-plus/es/components/dialog/style/css',
- 'element-plus/es/components/loading/style/css',
- 'element-plus/es/components/radio/style/css',
- 'element-plus/es/components/radio-group/style/css',
- 'element-plus/es/components/popover/style/css',
- 'element-plus/es/components/scrollbar/style/css',
- 'element-plus/es/components/tooltip/style/css',
- 'element-plus/es/components/dropdown/style/css',
- 'element-plus/es/components/dropdown-menu/style/css',
- 'element-plus/es/components/dropdown-item/style/css',
- 'element-plus/es/components/sub-menu/style/css',
- 'element-plus/es/components/menu-item/style/css',
- 'element-plus/es/components/divider/style/css',
- 'element-plus/es/components/card/style/css',
- 'element-plus/es/components/link/style/css',
- 'element-plus/es/components/breadcrumb/style/css',
- 'element-plus/es/components/breadcrumb-item/style/css',
- 'element-plus/es/components/table/style/css',
- 'element-plus/es/components/tree-select/style/css',
- 'element-plus/es/components/table-column/style/css',
- 'element-plus/es/components/select/style/css',
- 'element-plus/es/components/option/style/css',
- 'element-plus/es/components/pagination/style/css',
- 'element-plus/es/components/tree/style/css',
- 'element-plus/es/components/alert/style/css',
- 'element-plus/es/components/checkbox/style/css',
- 'element-plus/es/components/date-picker/style/css',
- 'element-plus/es/components/transfer/style/css',
- 'element-plus/es/components/tabs/style/css',
- 'element-plus/es/components/image/style/css',
- 'element-plus/es/components/tab-pane/style/css'
- ]
- }
- }
- })
|