处理axios的响应拦截器

处理axios的响应拦截器

axios返回的数据中默认增加了一层data的包裹,需要解构赋值

响应拦截器示意图

在这里插入图片描述

响应拦截器

  • service.interceptors.response.use(成功回调,失败回调)
// 导出一个axios的实例  而且这个实例要有请求拦截器 响应拦截器
import axios from 'axios'
import { Message } from 'element-ui'
// 创建一个axios的实例
const service = axios.create({
  // 当执行npm run div=> .evn.development=> /api =>跨域代理
  baseURL: process.env.VUE_APP_BASE_API, // 两个值(开发环境或生产环境)
  timeout: 5000 // 超时时间
})
// 请求拦截器
service.interceptors.request.use()
// 响应拦截器
service.interceptors.response.use(
  // 成功回调函数
  (response) => {
    // axios默认加一层data
    const { message, success, data } = response.data
    // 判断success
    if (success) {
      return data   //成功后直接返回data
    } else {
      Message.error(message)
      // 业务错误 进入catch  创建一个错误对象new Error
      return Promise.reject(new Error(message))
    }
  },
  // 失败回调函数
  (error) => {
    Message.error(error.message)// 提示错误信息
    return Promise.reject(error) // 返回执行错误 让当前的执行链跳出(then)成功 进入catch
  }
)
export default service // 导出axios实例
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Gik99

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

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

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

打赏作者

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

抵扣说明:

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

余额充值