【工作实践篇】等待轮询结果后再发请求

为啥会有这篇 ?

  • 一些同学说 想看 工作中常用的一些操作分享, 它来了

在一些场景下我们需要去重复请求接口 数据

经典场景

1. 多人点单 选择商品后需要 重复拉取 order 接口 获取最新订单信息
2. 审批状态比如多个人都在审批一个单 当一个人审批了 更改了审批状态 需要通知其他人 
...... 

实现

  • 其实 实现轮询 非常 简单* 先给一个 最简单轮询版本```
    this.timer = setInterval(async () => {await this.getList()
    },2000)

// 然后在适当时机清楚(比如 离开页面)
clearInterval(this.timer)


* 看起来 非常 简单 问题是 setInterval 并不会自我清除

`更优雅的方式`
--------

* 这样的好处是 setTimeout 会在每次结束 清除自己 且在 恰当时机 执行 time = 0 , 此处需要了解一下 宏认为/微任务* 但 无法解决 等待轮询结果后再发请求```
this.timer = setInterval(() => {
setTimeout(()=> {
...
},0)
},2000)

// 然后在适当时机清楚(比如 离开页面)
clearInterval(this.timer) 
  • (条件 网络 low 3G模拟接口慢的情况 轮询1s 测试快速发请求情况)

这样实现后 大概是 这样

  • 我们可以 很明确的发现 前一条 没有请求结束 后一条请求 又跟上了* 会出现这样的情况

  • 出现多个地方 接口 报错 ! 非常 不 nice

再优雅一波

const STATUS_INTERVAL = 2 * 1000const queryOrderStatus = () => {this.timer = setTimeout(async () => {await xxxxxqueryOrderStatus();}, STATUS_INTERVAL);};queryOrderStatus();// 然后在适当时机清楚(比如 离开页面)
clearInterval(this.timer) 
  • 实现效果
  • 有没有想过为啥 ? 递归 和 await 功效 good* 如果多个 请求 可叠加 / Promise.all(…)* 更多 技术实践 正在袭来 …

最后

整理了一套《前端大厂面试宝典》,包含了HTML、CSS、JavaScript、HTTP、TCP协议、浏览器、VUE、React、数据结构和算法,一共201道面试题,并对每个问题作出了回答和解析。

有需要的小伙伴,可以点击文末卡片领取这份文档,无偿分享

部分文档展示:



文章篇幅有限,后面的内容就不一一展示了

有需要的小伙伴,可以点下方卡片免费领取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值