vue 请求接口快慢 覆盖 解决方案

vue 请求接口快的被慢的覆盖的问题,有一个接口比较慢,当created去调用函数请求的时候,数据还没回来,就去筛选数据,筛选数据的调用比较快,很快就回来了,但当慢的相应回来之后,导致快的结果覆盖了慢的结果,如何解决呢?

注意:还有一个前提是:同一个接口,但是参数不同。


解决方案:

先不用AbortController去取消,我知道可能你想到的是这个。

而且一般项目当中都是封装在同一个请求文件,这个时候就需要考虑不同请求地址不同参数等等不同的前提条件。

所以首先考虑看看能不能用标识这种写法先去写,(如果需求催得急的情况):

js 复制代码
let currentRequestId = 0

async function fetchData(params) {
  const requestId = ++currentRequstId;
  
  try {
    const response = await api.get('/data', { params });
    
    // 检查是不是最新的请求,不是的话,不走下去了
    if (requestId !== currentRequestId) {
      return
    }
    
    return response.data;
    
  } catch (error) {
    if (requestId !== currentRequestId) {
      console.log('已忽略过时的错误')
      return
    }
    throw error
  }
}
相关推荐
牛马11116 小时前
Flutter 多语言
前端·flutter
by————组态16 小时前
集成详细说明
前端·物联网·信息可视化·组态·组态软件
我是小疯子6617 小时前
jQuery快速入门指南
前端
傻啦嘿哟17 小时前
Python中的@property:优雅控制类成员访问的魔法
前端·数据库·python
北辰alk17 小时前
Vue 自定义指令生命周期钩子完全指南
前端·vue.js
是小崔啊17 小时前
03-vue2
前端·javascript·vue.js
学习非暴力沟通的程序员17 小时前
Karabiner-Elements 豆包语音输入一键启停操作手册
前端
Jing_Rainbow17 小时前
【 前端三剑客-39 /Lesson65(2025-12-12)】从基础几何图形到方向符号的演进与应用📐➡️🪜➡️🥧➡️⭕➡️🛞➡️🧭
前端·css·html
刘羡阳17 小时前
使用Web Worker的经历
前端·javascript
!执行18 小时前
高德地图 JS API 在 Linux 系统的兼容性解决方案
linux·前端·javascript