封装axios

将axios封装成API的形式,而不是定义在Vue的原型上面,因为这样会造成原型的污染

1.在src/api文件夹下创建一个request.js文件

2.创建axios配置变量,根据node的环境变量来匹配baseURL

const axiosConfig = {
  baseURL: process.env.NODE_ENV === 'production' ? '' : '/api',
  responseType: 'json',
  responseEncoding: 'utf8',
  headers: {},
};

3.创建axios实例

const service = axios.create(axiosConfig)

4.配置拦截器,判断token、status等,这里返回resolve或者reject,后面可以通过then、catch捕获到

service.interceptors.request.use(config => {
  if (localStorage.getItem('token')) {
    config.headers.ACCESS_TOKEN = localStorage.getItem('token');
  }
  return config
}, error => {
  // 对请求错误做些处理
  console.log(error)
  return Promise.reject()
})

5.最后暴露出service实例

export default service

6.需要用到axios时,直接引入使用

import request from '@/api/request';
const getUserIds = params => {
  /*返回的是一个Promise对象*/
  return request({
    url: `${prefix}/user_attribute`,
    method: 'POST',
    data: params,
  })
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值