axios解决多个baseURL配置的几种方式

在开发初期,我们往往都会对axios进行初始化配置,把常用的 baseURL 通过环境变量或直接写死的方式配置好,这样就可以在接口请求的时候少写公共的url前缀,以达到减少代码量,提高可读性的目的。

封装示例:

import qs from 'qs'

const instance = axios.create({
  baseURL: '/api',
  transformRequest: [(data, headers) => {
    if(headers && headers['Content-Type'] === 'application/json'){
      return JSON.stringify(data)
    }
    return qs.stringify(data)
  }]
})

export default instance

但项目进行到中后期,又有了新的接口地址变化,需要新的代理接口,如果直接修改axios的 baseURL 就会造成以前的接口出问题,这是肯定不行的,但不管怎样问题还是要解决的,下面提供三个解决方式:

1、添加新的axio的实例封装

示例:

import qs from 'qs'

const instance = axios.create({
  baseURL: '/tapi',
  transformRequest: [(data, headers) => {
    if(headers && headers['Content-Type'] === 'application/json'){
      return JSON.stringify(data)
    }
    return qs.stringify(data)
  }]
})

export default instance

使用示例:

import axios from '@/plugins/taxios'

缺点:会多维护一份axios配置实例,增加文件数量

2、使用原生的axios处理

import axios from 'axios'

缺点:在某些请求的时候,特别是post请求,需要多写代码进行参数转换,不然后端接收不到请求参数

3、请求参数添加baseURL参数

这种方式比较推荐,因为代码量不多,而且还可以接着使用以前的封装

示例:

import axios from '@/plugins/axios'

// get
axios.get('/user/list', {params: {page: 1}, baseURL: '/tapi'}).then((res: any) => {
  console.log(res)
})

// post
axios.post('/user/set', {name: 'tom'}, {baseURL: '/tapi'}).then((res: any) => {
  console.log(res)
})

最新内容请查看原文链接:fenxianglu.cn/article/500

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天空还下着雪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值