接口错误码监听方法

背景

接口请求方法使用是的内部封装的,没办法直接像axios对相应结果进行拦截处理。但是又需要请求方式尽量保持统一并且处理错误信息弹框,所以找到该办法通过Proxy代理拦截

实现

js 复制代码
// 拷贝一份
const originalRequest = request; 
// 代理拦截
request = new Proxy(originalRequest, {
  apply(target, thisArg, argumentsList) {
    return target.apply(thisArg, argumentsList).then(response => {
      // 这里可以做一些响应处理
      return response;
    }).catch(error => {
      // 这里就可以做一些错误处理
      throw error;
    });
  }
});

GPT推荐方案

  • 方法 1:使用函数劫持
js 复制代码
// 备份原始 request 方法
const originalRequest = request;

request = async function (...args) {
  try {
    const response = await originalRequest(...args);
    console.log('HTTP 状态码:', response.status);

    // 这里可以添加额外的逻辑,比如错误处理
    if (response.status >= 400) {
      console.error('请求失败:', response.status);
    }

    return response;
  } catch (error) {
    console.error('请求异常:', error);
    throw error;
  }
};

方法 2:使用 Proxy 代理 request 方法

js 复制代码
const originalRequest = request;

request = new Proxy(originalRequest, {
  apply(target, thisArg, argumentsList) {
    console.log('请求参数:', argumentsList);

    return target.apply(thisArg, argumentsList).then(response => {
      console.log('HTTP 状态码:', response.status);
      
      if (response.status >= 400) {
        console.error('请求失败:', response.status);
      }

      return response;
    }).catch(error => {
      console.error('请求异常:', error);
      throw error;
    });
  }
});

方法 3:对象替换(适用于 request 是对象的方法)

js 复制代码
const originalRequest = api.request;

api.request = async function (...args) {
  console.log('拦截请求:', args);

  try {
    const response = await originalRequest.apply(this, args);
    console.log('HTTP 状态码:', response.status);
    return response;
  } catch (error) {
    console.error('请求错误:', error);
    throw error;
  }
};

🚀 总结

方法 适用场景 优势 适用难度
方法 1:函数劫持 request 是全局函数 简单易用,适合大多数情况
方法 2:Proxy 代理 request 可能有多个参数和上下文 灵活拦截,适用于更复杂场景 ⭐⭐
方法 3:对象方法替换 request 是对象方法(如 api.request() 适用于 SDK 或 api 对象封装 ⭐⭐
相关推荐
冬夜戏雪8 分钟前
实习面经记录(十)
java·前端·javascript
爱学习的程序媛1 小时前
【Web前端】JavaScript设计模式全解析
前端·javascript·设计模式·web
小码哥_常2 小时前
从SharedPreferences到DataStore:Android存储进化之路
前端
老黑2 小时前
开源工具 AIDA:给 AI 辅助开发加一个数据采集层,让 AI 从错误中自动学习(Glama 3A 认证)
前端·react.js·ai·nodejs·cursor·vibe coding·claude code
jessecyj2 小时前
Spring boot整合quartz方法
java·前端·spring boot
苦瓜小生2 小时前
【前端】|【js手撕】经典高频面试题:手写实现function.call、apply、bind
java·前端·javascript
天若有情6732 小时前
前端HTML精讲03:页面性能优化+懒加载,搞定首屏加速
前端·性能优化·html
踩着两条虫3 小时前
AI驱动的Vue3应用开发平台深入探究(十):物料系统之内置组件库
android·前端·vue.js·人工智能·低代码·系统架构·rxjava
swipe3 小时前
AI 应用里的 Memory,不是“保存聊天记录”,而是管理上下文预算
前端·llm·agent
慧一居士3 小时前
nuxt3 项目和nuxt4 项目区别和对比
前端·vue.js