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
  }
}
相关推荐
AAA阿giao5 小时前
JavaScript 执行机制深度解析:从 V8 引擎到作用域链、变量提升与闭包的全面剖析
前端·javascript·面试
一水鉴天5 小时前
整体设计 定稿 之19 拼语言表述体系之2(codebuddy)
大数据·前端·人工智能·架构
低代码的未来5 小时前
React CVE-2025-55182漏洞排查与修复指南
前端
脾气有点小暴5 小时前
CSS position 属性
前端·css
ohyeah5 小时前
用原生 JS 手写一个“就地编辑”组件:EditInPlace 的 OOP 实践
前端·javascript
timeweaver5 小时前
React Server Components 的致命漏洞CVE-2025-55182
前端·安全
重铸码农荣光5 小时前
深入理解 JavaScript 中的 this:一场关于作用域、调用方式与设计哲学的思辨
前端·javascript
新晨4375 小时前
跨域是服务器拒绝请求还是浏览器去拒绝的请求?
前端·浏览器
珑墨5 小时前
【包管理器】pnpm、npm、cnpm、yarn 深度对比
前端·javascript·npm·node.js
草字5 小时前
uniapp 滚动到表单的某个位置,表单验证失败时。
前端·javascript·uni-app