WholeProcessPlatform/frontend/vite.config.ts

64 lines
1.8 KiB
TypeScript
Raw Normal View History

2026-03-25 10:02:19 +08:00
import { UserConfig, ConfigEnv, loadEnv } from 'vite';
import vue from '@vitejs/plugin-vue';
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons';
import path from 'path';
export default ({ mode }: ConfigEnv): UserConfig => {
// 获取 .env 环境配置文件
const env = loadEnv(mode, process.cwd());
return {
plugins: [
vue(),
createSvgIconsPlugin({
// 指定需要缓存的图标文件夹
iconDirs: [path.resolve(process.cwd(), 'src/assets/icons')],
// 指定symbolId格式
symbolId: 'icon-[dir]-[name]'
})
],
// 本地反向代理解决浏览器跨域限制
server: {
host: '0.0.0.0',
port: Number(env.VITE_APP_PORT),
open: true, // 运行自动打开浏览器
proxy: {
[env.VITE_APP_BASE_API]: {
// 线上API地址
2026-04-20 16:57:54 +08:00
// target: 'http://10.84.121.4:8093/',
2026-03-25 10:02:19 +08:00
// 本地API地址
2026-03-31 14:17:30 +08:00
target: 'http://localhost:8093',
2026-03-25 10:02:19 +08:00
changeOrigin: true,
rewrite: path =>
path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')
},
2026-04-20 16:57:54 +08:00
'/geoserver': {
// target: 'https://211.99.26.225:18085', // 地图-线上API地址
target: 'http://172.16.31.112:18084', // 地图-本地API地址
changeOrigin: true,
secure: false,
rewrite: path => path.replace(new RegExp('^/geoserver'), '/geoserver')
},
'/process': {
target: 'http://localhost:5174',
changeOrigin: true
2026-03-25 10:02:19 +08:00
}
}
},
resolve: {
// Vite路径别名配置
alias: {
2026-03-27 14:50:35 +08:00
'@': path.resolve(__dirname, './src')
2026-03-25 10:02:19 +08:00
}
},
css: {
preprocessorOptions: {
scss: {
silenceDeprecations: ['legacy-js-api'],
api: 'modern-compiler' // 使用现代API
}
}
}
};
};