vue 在服务器端直接修改请求的接口地址


Posted in Vue.js onDecember 19, 2020

一个项目可能有很多环境,开发,测试,预生产,生产等环境,如果每一个环境都需要重新打包会显得比较麻烦,那么如何解决这个问题呢

在vue和uniapp中以及其他框架下的都是可以按照如下操作来解决的

在静态资源下新建一个env.json,vue项目是在public文件下新建,uniapp是在static下新建文件

文件格式如下

{
  "name": "development",
  "base": "/customer"
}

name,代表的是环境,方便直接在服务器上查看当前是什么环境的,base是请求的地址,如果服务器没有做代理的话,这里的base应该是完整的请求地址http:// xxxxx.com/customer,类似这种

一般人在处理的时候总是获取不到这个env.json里的地址,是因为,这里是因为异步导致的,如果要解决的话,可以在main.js或者是main.ts中如何操作

axios.get('./env.json')
 .then(function (res: any) {
  // handle success

Vue.prototype.BASE_URL = res.data.base;
  new Vue({
   router,
   store,
   render: h => h(App)
  }).$mount('#app')
 })

这样有个问题就是一定是在请求这个json成功之后项目才会开始渲染的,这个时间可以做一个加载动画,请求应该是很快的,如果请求失败,你可以在axios里做一个catch操作,给一个友好的提示什么的,进行重新请求

那么如何获取了?

可以在拦截器中进行获取然后拼接请求地址

在拦截器的那个js文件中

function getBaseUrl() {
  return Vue.prototype.BASE_URL
}

最后在传入url的时候进行拼接,如下
url: getBaseUrl() + opts.url, // opts是传过来的参数对象

就这样就可以正常请求了

一般开发环境下你env.json里可以配置你的开发地址,最后通过自动化打包部署到服务器上去之后,如果要换成其他环境(测试,预生产,生产)的地址,可以直接在服务器上直接修改这个env.json文件即可,

大功告成,哈哈

以上就是vue 在服务器端直接修改请求的接口地址的详细内容,更多关于vue 修改请求接口地址的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
Vue实现图书管理小案例
Dec 03 Vue.js
vuex的使用步骤
Jan 06 Vue.js
如何封装Vue Element的table表格组件
Feb 06 Vue.js
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 Vue.js
SSM VUE Axios详解
Oct 05 Vue.js
Vue.js中v-bind指令的用法介绍
Mar 13 Vue.js
vue-cil之axios的二次封装与proxy反向代理使用说明
Apr 07 Vue.js
分享一个vue实现的记事本功能案例
Apr 11 Vue.js
如何vue使用el-table遍历循环表头和表体数据
Apr 26 Vue.js
vue如何清除浏览器历史栈
May 25 Vue.js
vue router 动态路由清除方式
May 25 Vue.js
vue 通过base64实现图片下载功能
Dec 19 #Vue.js
Vue中computed和watch有哪些区别
Dec 19 #Vue.js
Vue与React的区别和优势对比
Dec 18 #Vue.js
Vue实现指令式动态追加小球动画组件的步骤
Dec 18 #Vue.js
vue+elementUI动态增加表单项并添加验证的代码详解
Dec 17 #Vue.js
vue 数据操作相关总结
Dec 17 #Vue.js
Vue 组件注册全解析
Dec 17 #Vue.js
You might like
简单的php数据库操作类代码(增,删,改,查)
2013/04/08 PHP
使用php转义输出HTML到JavaScript
2015/03/27 PHP
WordPress中获取指定分类及其子分类下的文章数目
2015/12/31 PHP
thinkPHP框架可添加js事件的分页类customPage.class.php完整实例
2017/03/16 PHP
Avengerls vs Newbee BO3 第一场2.18
2021/03/10 DOTA
JavaScript的漂亮的代码片段
2013/06/05 Javascript
浅谈JavaScript Math和Number对象
2015/01/26 Javascript
javascript实现uploadify上传格式以及个数限制
2015/11/23 Javascript
基于javascript实现仿百度输入框自动匹配功能
2016/01/03 Javascript
JavaScript中的数组遍历forEach()与map()方法以及兼容写法介绍
2016/05/19 Javascript
jQuery实现别踩白块儿网页版小游戏
2017/01/18 Javascript
Vue2学习笔记之请求数据交互vue-resource
2017/02/23 Javascript
Nodejs模块的调用操作实例分析
2018/12/25 NodeJs
微信小程序第三方框架对比 之 wepy / mpvue / taro
2019/04/10 Javascript
微信小程序自定义组件传值 页面和组件相互传数据操作示例
2019/05/05 Javascript
javascript中this的用法实践分析
2019/07/29 Javascript
使用node.JS中的url模块解析URL信息
2020/02/06 Javascript
[58:00]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Elephant BO3 第二场 2月7日
2021/03/11 DOTA
Python实现合并同一个文件夹下所有txt文件的方法示例
2018/04/26 Python
python反编译学习之字节码详解
2019/05/19 Python
Python 列表去重去除空字符的例子
2019/07/20 Python
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
2018/01/03 HTML / CSS
HTML5 canvas基本绘图之文字渲染
2016/06/27 HTML / CSS
H5 video poster属性设置视频封面的方法
2020/05/25 HTML / CSS
英国最大的手表网站:The Watch Hut
2017/03/31 全球购物
美国在线鞋类零售商:LifeStride
2019/06/09 全球购物
世界上最大的冷却器制造商:Igloo Coolers
2019/07/23 全球购物
Discard Protocol抛弃协议的作用是什么
2015/10/10 面试题
电子专业毕业生自我鉴定
2014/01/22 职场文书
家居饰品店创业计划书
2014/01/31 职场文书
财务会计自荐信范文
2014/02/21 职场文书
宣传标语大全
2014/07/01 职场文书
商业用房租赁协议书
2014/10/13 职场文书
2014年幼儿园班级工作总结
2014/12/17 职场文书
2015年教务主任工作总结
2015/07/22 职场文书
GO中sync包自由控制并发示例详解
2022/08/05 Golang