前景
一般vue多环境配置涉及三个文件:.env.development,.env.production,.env.test去配置,通过执行不同命令来区分运行环境。现在公司要求前端不要写死ip地址,防止部署的时候忘记更换命令部错包,通过nginx去代理配置不同端口。 现要求的配置文件
VUE_APP_BASE_API = 'http://aaaa:8080'
VUE_APP_BASE_API_WEBSOCKET = 'ws://sss:8080'
VUE_APP_BASE_API = '/gateway'
VUE_APP_BASE_API_WEBSOCKET = '/socket'
问题来了
通过上面的方式正常的http请求是可以正常访问的,但是websocket代理的地址不行,websocket请求必须要加上ip和端口才行(VUE_APP_BASE_API_WEBSOCKET = 'ws://xxxx:8080/socket’可以正常访问),但是不能写成“VUE_APP_BASE_API_WEBSOCKET = ‘ws://xxxx:8080/socket’” 必须要写活
websocket-api.js文件(websocket接口请求文件)
const env = process.env.NODE_ENV
const wsUrl = env === 'development' ? process.env.VUE_APP_BASE_API_WEBSOCKET : `ws://${window.document.location.host}/socket`
export const cityData = (userId) => {
return `${wsUrl}/getContinentStatistics/18`
}
|