vite.config.js 2.34 KB
import {defineConfig, loadEnv} from 'vite'
import path, {resolve} from 'path'
import createVitePlugins from './vite/plugins'
import inject from '@rollup/plugin-inject'
import commonjs from '@rollup/plugin-commonjs'

export default defineConfig(({mode, command}) => {
    const env = loadEnv(mode, process.cwd())
    return {
        // 部署生产环境和开发环境下的URL。
        // 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上
        base: env.VITE_APP_CONTEXT_PATH,
        plugins: [
            createVitePlugins(env, command === 'build'),
            commonjs(),
            inject({
                include: ['node_modules/**'],
                'window.katex': 'katex',
                'window.Quill': ['@vueup/vue-quill', 'Quill']
            })
        ],
        resolve: {
            alias: {
                // 设置路径
                '~': path.resolve(__dirname, './'),
                // 设置别名
                '@': path.resolve(__dirname, './src'),
                '/@': path.resolve(__dirname, './src')
            },
            // https://cn.vitejs.dev/config/#resolve-extensions
            extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']
        },
        // vite 相关配置
        server: {
            port: 5180,
            host: true,
            open: true,
            proxy: {
                '/dev-api/portal': {
                    // target: 'http://116.63.185.147:8088',
                    target: 'https://ff9451fo0879.vicp.fun',
                    changeOrigin: true,
                    rewrite: (p) => p.replace(/^\/dev-api\/portal/, '')
                }
            }
        },
        css: {
            postcss: {
                plugins: [
                    {
                        postcssPlugin: 'internal:charset-removal',
                        AtRule: {
                            charset: (atRule) => {
                                if (atRule.name === 'charset') {
                                    atRule.remove()
                                }
                            }
                        }
                    }
                ]
            }
        },
        build: {
            rollupOptions: {
                input: {
                    main: resolve(__dirname, 'index.html')
                }
            }
        }
    }
})