vue axios 给生产环境和发布环境配置不同的接口地址(推荐)
程序员文章站
2023-10-17 18:23:43
本项目是vue-cli搭建的项目框架,引入axios用于数据请求。配置不同的接口地址,(首先确保已经集成了axios,如对集成axios有疑问的道友,可参看我之间的一篇)操...
本项目是vue-cli搭建的项目框架,引入axios用于数据请求。配置不同的接口地址,(首先确保已经集成了axios,如对集成axios有疑问的道友,可参看我之间的一篇)操作如下
一、设置不同的接口地址
找到如下文件
/config/dev.env.js
/config/prod.env.js
之后增加接口地址域名配置,增加后的文件内容如下
二、在自己重新封装的axios文件中(api/api.js),将配置好的接口地址作为baseurl拼接到接口路径中
详细的api.js文件可参考如下代码,根据自己公司项目组编码习惯可自作调整
// 配置api接口地址 var root = process.env.api // 引用axios var axios = require('axios') // 自定义判断元素类型js function totype (obj) { return ({}).tostring.call(obj).match(/\s([a-za-z]+)/)[1].tolowercase() } // 参数过滤函数 function filternull (o) { for (var key in o) { if (o[key] === null) { delete o[key] } if (totype(o[key]) === 'string') { o[key] = o[key].trim() } else if (totype(o[key]) === 'object') { o[key] = filternull(o[key]) } else if (totype(o[key]) === 'array') { o[key] = filternull(o[key]) } } return o } function apiaxios (method, url, params, success, failure) { if (params) { params = filternull(params) } axios({ method: method, url: url, data: method === 'post' ? params : null, params: method === 'get' ? params : null, baseurl: root, withcredentials: false }) .then(function (res) { console.log(res); return; if (res.data.success === true) { if (success) { success(res.data) } } else { if (failure) { failure(res.data) } else { window.alert('error: ' + json.stringify(res.data)) } } }) .catch(function (err) { let res = err.response if (err) { window.alert('api error, http code: ' + res.status) return } }) } // 返回在vue模板中的调用接口 export default { get: function (url, params, success, failure) { return apiaxios('get', url, params, success, failure) }, post: function (url, params, success, failure) { return apiaxios('post', url, params, success, failure) } }
三、修改main.js,引入自己重新封装好的axios文件(api/api.js),修改好的文件如下图所示
四、在页面中调用,测试是否生效,开发环境调通后,build之后查看正式环境是否也生效
直接调用ajax请求
export default { created(){ this.$http.post('web/test',null, res => { console.log(res) }) } }
总结
以上所述是小编给大家介绍的vue axios 给生产环境和发布环境配置不同的接口地址,希望对大家有所帮助