123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- 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
- }
- }
- },
- 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',
- outDir: env.VITE_OUT_DIR || 'dist',
- sourcemap: env.VITE_SOURCEMAP === 'true' ? 'inline' : false,
- chunkSizeWarningLimit: 2000,
- reportCompressedSize: false,
- cssCodeSplit: true,
- emptyOutDir: true,
- target: 'esnext',
- assetsInlineLimit: 4096,
- rollupOptions: {
- output: {
- manualChunks: {
- 'element-plus': ['element-plus'],
- 'echarts': ['echarts'],
- 'vue': ['vue', 'vue-router', 'pinia', '@vueuse/core'],
- 'libs': ['axios', 'dayjs', '@wangeditor/editor'],
- },
- chunkFileNames: 'assets/js/[name]-[hash].js',
- entryFileNames: 'assets/js/[name]-[hash].js',
- assetFileNames: 'assets/[ext]/[name]-[hash].[ext]'
- },
- maxParallelFileOps: 20,
- }
- },
- optimizeDeps: {
- include,
- exclude,
- esbuildOptions: {
- target: 'esnext',
- minify: true,
- minifyIdentifiers: true,
- minifySyntax: true,
- minifyWhitespace: true,
- treeShaking: true,
- }
- },
- esbuild: {
- pure: env.VITE_DROP_CONSOLE === 'true' ? ['console.log', 'debugger'] : [],
- target: 'esnext',
- treeShaking: true,
- minifyIdentifiers: true,
- minifySyntax: true,
- minifyWhitespace: true,
- legalComments: 'none'
- }
- }
- }
|