多个promise调用顺序,javascript引擎的微任务和队列任务,promise(三)

文章详细探讨了多个异步函数的调用顺序,重点在于Promise链的执行逻辑,尤其是then()和catch()的执行时机,以及它们与setTimeout的关系。作者指出,Promise回调作为微任务,而setTimeout作为任务队列,这对于理解JavaScript的事件循环机制和在单页应用中的实际运用至关重要。
摘要由CSDN通过智能技术生成

多个异步函数的调用顺序:运行代码得到的结果是p1,p2,p4,p3

    const p1 = new Promise((resolve, reject) => reject(Error('p1抛出的错误'))).catch(error => console.log(error))
    const p2 = new Promise((resolve, reject) => reject(Error('p2抛出的错误'))).catch(error => console.log(error))
    const p3 = new Promise((resolve, reject) => resolve('xx')).then(() => {
        throw  Error('p3抛出的错误')
    }).catch(error => console.log(error))
    const p4 = new Promise((resolve, reject) => reject(Error('p4抛出的错误'))).catch(error => console.log(error))

解释:then()的回调用会产生新的期约,新的期约的函数不会立即运行,而是被放入微任务队列中,这意味着它会在稍后运行。在下一次事件循环的时候再次排队
以上的例子再复杂一点:运行代码得到的结果是p1,p4,p3,p2

    const p1 = new Promise((resolve, reject) => reject(Error('p1抛出的错误'))).catch(error => console.log(error))
    const p2 = new Promise((resolve, reject) => reject(Error('p2抛出的错误'))).then(error =>  error).then(error =>  error).catch(error => console.log(error))
    const p3 = new Promise((resolve, reject) => resolve('xx')).then(() => {
        throw  Error('p3抛出的错误')
    }).catch(error => console.log(error))
    const p4 = new Promise((resolve, reject) => reject(Error('p4抛出的错误'))).catch(error => console.log(error))

3.promise结合setTimeout案例

  const p1 = new Promise((resolve, reject) => {
      console.log('1.这里是同步的代码,Promise里面按顺序调用')
      resolve('接口返回数据')
    })
    .then((value) => {
      console.log('then1', value)
      return value
    })
    .then((value) => {
      console.log('then2', value)
      return value
    })
    .catch(error => console.log(error))
    setTimeout(() => {
      console.log('setTimeout是最后吗')
    },0)
    console.log('2.这里是同步的代码,程序流在外面')
// 1.这里是同步的代码,Promise里面按顺序调用
// 2.这里是同步的代码,程序流在外面
// then1 接口返回数据
// then2 接口返回数据
// setTimeout是最后吗

Promise 回调被处理为微任务,而 setTimeout() 回调被处理为任务队列。
其实setTimeout结合Promise在单页运用中,配合请求接口,渲染数据很有作用。
后续再结合单页出几个案例
请大家持续关注哦~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值