前端请求竞态问题

什么是前端请求竞态问题

前端请求竞态问题是指:在用户频繁触发数据请求(如搜索、切换筛选条件等)时,多个异步请求可能同时进行,导致后发请求的结果比先发请求更晚返回,最终页面显示了过时的数据。

举例:用户快速输入搜索框,连续发起多次请求。如果第一个请求最后才返回,页面会显示第一个请求的数据,而不是最新输入对应的数据。这会造成数据展示不准确、用户体验差。

SWR是如何解决前端请求竞态的问题

SWR 通过"请求标识"和"最新请求优先"机制解决前端请求竞态问题。每次请求都会生成唯一的 key(如 genKey),只有最后一次请求的结果会被渲染到页面。即使前面的请求晚于后面的请求返回,SWR 也会忽略旧请求的数据,确保页面始终展示最新请求的结果,从而避免数据错乱。

SWR解决前端请求竞态的源码

执行分析

  • startAt 是一个闭包变量,每一个请求都会有自己的startAt(唯一时间戳);
  • FETCH是一个对象,相同key的后一次请求都会覆盖前一个请求存储在FETCH[key][1]中的startAt, 所以FETCH[key][1]中永远都是最后一次请求的startAt。
  • 通过对比FETCH[key][1]和闭包变量startAt 可以筛选出最后一次请求。
相关推荐
剪刀石头布啊1 分钟前
css实现一个宽高固定百分比的布局的一个方式
前端
剪刀石头布啊5 分钟前
js数组之快速组、慢数组、密集数组、稀松数组
前端
mango_mangojuice26 分钟前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
Days20501 小时前
简单处理接口返回400条数据本地数据分页加载
前端
Novlan11 小时前
@tdesign/uniapp 图标瘦身
前端
ManThink Technology1 小时前
如何使用EBHelper 简化EdgeBus的代码编写?
java·前端·网络
. . . . .2 小时前
shadcn组件库
前端
2501_944711432 小时前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜2 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
css趣多多3 小时前
ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑
前端