Heading for the future

JS实现串行请求

使用async和await

1 var fn = async function(promiseArr) {
2     for(let i = 0,len = arr.length; i<len; i++) {
3         currentPromise = (promiseArr[i] instanceOf Promise) ? promiseArr[i]  : Promise.resolve(promiseArr[i]);
4         var result = await currentPromise;
5         console.log(result)
6     }
7  }   
8  fn(arr)

Promise实现

依照 promises 规范,一旦一个 promise 被创建,它就被执行了。如果then方法里返回的是一个promise对象,那么执行下一个then 的时候必定是在上一个then执行完之后执行。

关键点在于then的时候再创建

复制代码
 1 var createPromise = function(time) {
 2     return (resolve, reject)=> {
 3       return new Promise((resolve, reject)=>{
 4           setTimeout(()=>{
 5               console.log('timein'+time)
 6               resolve();
 7           }, time*1000)
 8       })
 9     }
10 }
11 
12 function serpromise(arr) {
13     arr.reduce((pre, next, index, carr)=>{
14         return pre.then(next)
15     }, Promise.resolve())
16 }
17 
18 var arr=[createPromise(2),createPromise(1),createPromise(3),createPromise(4),createPromise(5)];
19 // 相当于
20 // Promise.resolve().then(createPromise(2)).then(createPromise(1))......
21 serpromise(arr)
复制代码

参考自

https://cloud.tencent.com/developer/article/1525757

https://www.jianshu.com/p/3cb6ab992adb

posted @   一只菜鸟攻城狮啊  阅读(2271)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示