vue公共URL 定义方法(六)

这里写自定义目录标题

定义公共变量

vue3.0中,放在public文件夹下文件并不一定会不被打包。如果在main.js中直接引用,肯定会被webpack打包。如下写法在打包后,及时更改了url.js中的url地址,更改后的地址还是无效的。
1、目录结构:
在这里插入图片描述
2、url.js内容

export const httpUrl="http://10.88.44.142:8080";

3、main.js内容

import {httpUrl} from '../public/url';
Vue.prototype.httpUrl=httpUrl;

4、在文件中的使用

var socket = new SockJS(this.httpUrl + "/ws");

正确的方式

1、url.js

window.globalConfig = {
  	"apiUri": "http://10.88.44.142:8080"
}

2、config.js

import Vue from 'vue'
const API_BASE_URI = window.globalConfig.apiUri
Vue.prototype.$httpUrl = API_BASE_URI
var config = {
  API_BASE_URI: API_BASE_URI
}
export default config

3、main.js

import config from './config'

4、index.html

  <script src="./url.js" type="text/javascript"></script>

5、在文件中使用

var socket = new SockJS(this.$httpUrl + "/ws");

原因解释

main.js中引用的文件肯定会被webpack打包,所以直接引用url.js,会将url.js打包。
需要在config.js中引用url.js中定义的全局变量,然后将config.js打包。因为config中的变量不是固定的,所以打包进webpack还是可以通过更改url来更改config。
这样的话,可以打包后更改调用的后台地址,而不用重新打包。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值