我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么消除axios拦截中的if

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么消除axios拦截中的if

今天小编给大家分享一下怎么消除axios拦截中的if的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

    基本拦截

    axios的响应错误拦截中,难免会对error.status做各种各样的if判断,又或者switch。为了防止枯燥乏味的生活(给自己挖坑,换一种姿势去写拦截

    // 以下大概是日常碰到的操作,拦截响应,判断status做相应操作function login () {  console.log('登陆逻辑')  return promise.reject(error)}// 添加响应拦截器axios.interceptors.response.use(function (response) {  // 对响应数据做点什么  return response;}, function (error) {  if (error.status === 401) {    // 401重新登录    console.log('未登陆')    return login(error)  } else if (error.status === 404) {    console.log('404-什么都没')    return promise.reject(error)  } else if (error.status === 422) {    console.log(error.response.data.message)    return promise.reject(error)  } else if (error.status === 500) {    console.log('服务器内部错误')    return promise.reject(error)  } else {    // 其他请求,直接抛出让业务去处理    return promise.reject(error)  }});

    设计轮子

    思考方向

    首先思考下怎么实现这个东西

    • 需要一个在内部消化if的逻辑判断

    • 根据判断去执行相应的逻辑,意味着我们要在内部维护一个逻辑数组(以下称为管道数组),配合成功后即触发对应管道。所以在开始调用函数去执行前,先要收集好管道。这个方法需要传一个标记(用来判断是否匹配)和回调函数(匹配成功后的逻辑)

    • 除了传标记,需要传一个payload(例如拦截中的error)参数,payload可以让我们在回调函数做出更多的对应操作

    • 在最后再添加一个default函数来收集匹配失败后的函数。

    现在,已经在心中拟好了一个小轮子的五脏六腑。

    轮子骨架

    // 定义个一个classclass Enterclose {  constructor () {    // 维护管道数组    this.pond = {}    // 默认管道    this._default = null  }    use (sign, callback) {    return this  }    default (callback) {    this._default = callback    return this  }    start (sign, payload) {  }}

    详细实现

    以上把基本的api骨架写好,然后再一个一个慢慢实现内部的逻辑。

    首先是use,用来收集管道,需求中标记是唯一的,所以我们的this.ponds的结构是{标记: callback}

    use (sign, callback) {    this.ponds[sign] = callback    return this}

    其中我们需要一个方法用来启动Enterclose

    通过getCallback函数去筛选和标记匹配的管道,返回对应的函数。这样一个消除if的小轮子就搞好啦

    start (sign, payload) {    const fn = this.getCallback(sign)    if (fn) {      return fn(payload)    }}getCallback (sign) {    const key = Object.keys(this.ponds).find(key => key === sign)    if (key) {      return this.ponds[key]    } else if (this._default) {      return this._default    }}

    实践

    创建实例,用use和default收集管道,然后在拦截中通过start触发判断

    const enterclose = new Enterclose()// 收集管道enterclose.use(401, function (error) {  console.log('未登陆')  return login(error)}).use(404, function (error) {  console.log('404-什么都没')  return promise.reject(error)}).use(429, function (error) {  console.log(error.response.data.message)  return promise.reject(error)}).use(500, function (error) {  console.log('服务器内部错误')  return promise.reject(error)}).default(function (error) {  // 收集默认管道  return promise.reject(error)})axios.interceptors.response.use(function (response) {  // 对响应数据做点什么  return response;}, function (error) {  // 启动  return enterclose.start(error.status, error)});

    你也可以根据自己的场景做一些调整,例如支持Promise啊,或者说加一个finally函数,每次走管道最后都会调用这个回调函数之类

    以上就是“怎么消除axios拦截中的if”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    怎么消除axios拦截中的if

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    怎么消除axios拦截中的if

    今天小编给大家分享一下怎么消除axios拦截中的if的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。基本拦截axios的响应错
    2023-06-30

    spring中的拦截器怎么利用注解实现

    本篇文章给大家分享的是有关spring中的拦截器怎么利用注解实现,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。类似用户权限的需求,有些操作需要登录,有些操作不需要,可以使用过滤
    2023-05-31

    MyBatis中怎么实现自定义的SQL拦截器

    在 MyBatis 中实现自定义的 SQL 拦截器,通常可以通过实现 org.apache.ibatis.plugin.Interceptor 接口来实现。下面是一个简单的示例:创建一个自定义的拦截器类,实现 Interceptor 接口:
    MyBatis中怎么实现自定义的SQL拦截器
    2024-05-08

    rabbitmq怎么删除队列中的消息

    要删除RabbitMQ队列中的消息,需要使用RabbitMQ的管理界面或者通过编程方式使用RabbitMQ的API。使用RabbitMQ的管理界面:打开RabbitMQ的管理界面,通常在http://localhost:15672/。登录
    2023-10-23

    java怎么消除数组中重复出现的值

    可以使用Set来消除数组中重复出现的值。Set是一个不允许有重复元素的集合,可以用来存储数组中的元素,然后再将Set转换回数组。以下是一个示例代码:javaimport java.util.Arrays;import java.util.H
    2023-10-20

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录