import { fileURLToPath, URL } from 'node:url'
|
|
import { defineConfig, loadEnv } from 'vite'
|
import vue from '@vitejs/plugin-vue'
|
import vueJsx from '@vitejs/plugin-vue-jsx'
|
|
import AutoImport from 'unplugin-auto-import/vite'
|
import Components from 'unplugin-vue-components/vite'
|
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
|
|
// https://vitejs.dev/config/
|
export default defineConfig(({mode, command}) => {
|
let env = loadEnv(mode, process.cwd(), '')
|
// console.log('-------');
|
// console.log(env.VITE_BASE_PATH);
|
// console.log(env.VITE_BASE_PATH.replace(env.VITE_BASE_PATH, ''));
|
// console.log('-------');
|
return {
|
base:env.VITE_BASE_CONTEXT,
|
plugins: [
|
vue(),
|
vueJsx(),
|
AutoImport({
|
resolvers: [ElementPlusResolver()],
|
}),
|
Components({
|
resolvers: [ElementPlusResolver()],
|
}),
|
],
|
resolve: {
|
alias: {
|
'@': fileURLToPath(new URL('./src', import.meta.url))
|
}
|
},
|
// 打包配置
|
build: {
|
target: 'modules',
|
outDir: env.VITE_BASE_CONTEXT, //指定输出路径
|
assetsDir: 'assets', // 指定生成静态资源的存放路径
|
minify: 'terser' // 混淆器,terser构建后文件体积更小
|
},
|
|
// 本地运行配置,及反向代理配置
|
server: {
|
host: '192.168.0.3',
|
port: '1801',
|
cors: true, // 默认启用并允许任何源
|
open: true, // 在服务器启动时自动在浏览器中打开应用程序
|
//反向代理配置,注意rewrite写法,开始没看文档在这里踩了坑
|
proxy: { // 本地开发环境通过代理实现跨域,生产环境使用 nginx 转发
|
[env.VITE_BASE_PATH] : {
|
target: env.VITE_BASE_URL, // 通过代理接口访问实际地址。这里是实际访问的地址。vue会通过代理服务器来代理请求
|
changeOrigin: true,
|
ws: false, // 允许websocket代理
|
secure: false,
|
rewrite: (path) => path.replace(env.VITE_BASE_PATH, '/')
|
}
|
}
|
}
|
}
|
|
})
|