Axios拦截器

在请求或响应被 thencatch 处理前拦截它们。

<template>
  <div class="axios"></div>
</template>

拦截器:在请求或响应被处理前拦截它们
分为:请求拦截器响应拦截器

<script>
import axios from 'axios'

export default {
  name: 'axios3-3',
  created() {
    // 请求拦截器
    axios.interceptors.request.use(config => {  // 在发送请求前做些什么
      return config
    }, err => { // 在请求错误的时候做些什么
      return Promise.reject(err)
    })

    // 响应拦截器
    axios.interceptors.response.use(res => {  // 请求成功对响应数据做处理
      return res
    }, err => { // 响应错误做些什么
      return Promise.reject(err)
    })

    // 取消拦截器(了解即可)
    const myInterceptor = axios.interceptors.request.use(config => { // 声明变量myInterceptor,把拦截器存放在变量myInterceptor中
      config.headers = {
        auth: true
      }
      return config
    })
    axios.interceptors.request.eject(myInterceptor) // 取消拦截器

    // 例子1  登录状态(token:'') 需要登录的接口
    const instance = axios.create({}) // 自定义 axios 实例添加拦截器
    instance.interceptors.request.use(config => { // 在发送请求前赋值token
      config.headers.token = ''
      return config
    })
    // 不需要登录的接口
    const newInstance = axios.create({})

    // 例子2  移动端开发
    const instance_phone = axios.create({})
    instance_phone.interceptors.request.use(config => { // 在发送请求前显示#modal弹框
      $('#modal').show()
      return config
    })
    instance_phone.interceptors.response.use(res => { // 请求成功隐藏#modal弹框
      $('#modal').hide()
      return res
    })
  },
}
</script>

如果你想在稍后移除拦截器,可以这样:

const myInterceptor = axios.interceptors.request.use(function () {/*...*/});
axios.interceptors.request.eject(myInterceptor);

可以为自定义 axios 实例添加拦截器

const instance = axios.create();
instance.interceptors.request.use(function () {/*...*/})
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Axios 拦截器是一种在请求发送和响应返回之前,对请求和响应进行处理的机制。Axios 拦截器可以用于添加请求头、验证请求数据、对响应数据进行处理等场景。 Axios拦截器是基于 Promise 实现的,每个拦截器都是一个 Promise,其 resolve 函数接收一个 config 对象或 response 对象作为参数。Axios 支持两种类型的拦截器:请求拦截器和响应拦截器。 请求拦截器会在请求发送之前执行,响应拦截器会在响应返回之后执行。请求拦截器可以用于添加请求头、验证请求数据等操作,响应拦截器可以用于对响应数据进行处理。 Axios拦截器原理可以简单概括为: 1. 创建一个 Axios 实例,并设置默认配置。 2. 将请求和响应拦截器添加到实例中。 3. 当发送请求时,按照顺序执行请求拦截器中的代码。 4. 如果请求拦截器中发生了错误,Promise.reject() 方法会直接返回错误信息。 5. 如果请求拦截器中没有发生错误,Axios 会将最终的请求参数发送给服务器。 6. 当服务器返回响应时,Axios 会按照顺序执行响应拦截器中的代码。 7. 如果响应拦截器中发生了错误,Promise.reject() 方法会返回错误信息。 8. 如果响应拦截器中没有发生错误,Axios 会将最终的响应结果返回给调用者。 总之,Axios 拦截器的原理就是在请求和响应之间插入一些处理代码,以实现对请求和响应的自定义处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值