import { UserConfig, ConfigEnv, loadEnv, defineConfig } from 'vite'; import createPlugins from './vite/plugins'; import path from 'path'; import { gitCommitHashPlugin } from "vite-plugin-git-commit-hash"; const timeStamp = new Date().getTime(); export default defineConfig(({ mode, command }: ConfigEnv): UserConfig => { const env = loadEnv(mode, process.cwd()); return { base: env.VITE_APP_CONTEXT_PATH, resolve: { alias: { '~': path.resolve(__dirname, './'), '@': path.resolve(__dirname, './src') }, extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue'] }, // https://cn.vitejs.dev/config/#resolve-extensions plugins: [createPlugins(env, command === 'build'),gitCommitHashPlugin()], server: { host: '0.0.0.0', port: Number(env.VITE_APP_PORT), open: true, proxy: { [env.VITE_APP_BASE_API]: { target: 'http://192.168.1.1:6666', changeOrigin: true, ws: true, rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '') } } }, css: { preprocessorOptions: { scss: { javascriptEnabled: true } }, postcss: { plugins: [ { postcssPlugin: 'internal:charset-removal', AtRule: { charset: (atRule) => { if (atRule.name === 'charset') { atRule.remove(); } } } } ] } }, build: { outDir: "dist", //想要把dist修改成什么名字在这边改 // 自定义底层的 Rollup 打包配置(Rollup文档地址:https://cn.rollupjs.org/configuration-options/) rollupOptions: { // 输出配置 output: { // 输出的文件自定义命名 chunkFileNames: `assets/[name]-[hash].${timeStamp}.js`, entryFileNames: `assets/[name]-[hash].${timeStamp}.js`, assetFileNames: `assets/[name]-[hash].${timeStamp}.[ext]`, } }, }, // 预编译 optimizeDeps: { include: [ 'vue', 'vue-router', 'pinia', 'axios', '@vueuse/core', 'echarts', // 'path-to-regexp', // '@wangeditor/editor', // '@wangeditor/editor-for-vue', // '@vueup/vue-quill', // '@iconify/iconify', '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' ] } }; });