实现一个executPromise 函数,按传参的顺序先后执行,将返回数据按照先后顺序放到数组中

 

 

1.要求不能使用async/await ,请使用Promise的方式实现 

const timeout = (ms) => new Promise((resolve) => {
  setTimeout(() => {
    resolve()
  }, ms)
})

const ajax1 = () => timeout(2000).then(() => {
  console.log('1')
  return 1
})

const ajax2 = () => timeout(1000).then(() => {
  console.log('2')
  return 2
})


const ajax3 = () => timeout(2000).then(() => {
  console.log('3')
  return 3
})


const executePromise = (ajaxArray) => {
  // 不能使用async/await ,请使用Promise的方式实现

}

executePromise([ajax1, ajax2, ajax3]).then(data => {
  console.log('done')
  console.log(data)
})


// 要求分别输出
// 1
// 2
// 3
// done
// [1,2,3]

有一个概念是只有返回promsie对象后才会链式调用。就是说我们可以在 executePromise 函数中返回一个Promise 让传入的 [ajax1,ajax2,ajax3], 顺序执行完后使用reslove() ;方法结束当前Promise状态,最后调用函数的then方法就会执行啦。

好,现在我们只需要考虑 executePromise 函数 中传入的Promise 顺序执行异步任务就行了

且由于每次调用then都会创建一个新的promise实例,所以只有当执行完 return "Promsie"后,then返回一个值为Promise的promise对象,才会继续链式调用then。

利用Promise.resolve()+forEach循环/reduce循环,将promise串成一任务队列,本质上是简化的链式调用。

const executePromise = (ajaxArray) => {
  // 不能使用async/await ,请使用Promise的方式实现
  return new Promise((resolve) => {
    let promise = Promise.resolve()
    let result = []
    for (let i = 0; i < ajaxArray.length; i++) {
      promise = promise.then(ajaxArray[i]).then(res=> {
        result.push(res)
      })
    }
    promise.then(()=> {
      resolve(result)
    })
  })
}

end: 完结🥳

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值