美文网首页
es6--Promise.all()和Promise.race(

es6--Promise.all()和Promise.race(

作者: 花拾superzay | 来源:发表于2020-01-14 21:08 被阅读0次

    Promise.all的使用

    Promise.all可以将多个Promise实例包装成一个新的Promise实例。同时,成功和失败的返回值是不同的,成功的时候返回的是一个结果数组,而失败的时候则返回最先被reject失败状态的值。

    
    let p1 = new Promise((resolve, reject) => {
      resolve('成功了')
    })
    
    let p2 = new Promise((resolve, reject) => {
      resolve('success')
    })
    
    let p3 = Promse.reject('失败')
    
    
    Promise.all([p1, p2]).then((result) => {
      console.log(result) //['成功了', 'success']
    }).catch((error) => {
      console.log(error)
    })
    
    
    Promise.all([p1,p3,p2]).then((result) => {
      console.log(result)
    }).catch((error) => {
      console.log(error) // 失败了,打出 '失败'
    })
    
    

    Promise.race的使用

    race和all用法类似。Promse.race方法顾名思义就是赛跑的意思,意思就是说,Promise.race([p1, p2, p3])里面哪个结果获得的快,就返回那个结果,不管结果本身是成功状态还是失败状态。

    let p1 = new Promise((resolve, reject) => {
      setTimeout(() => {
        resolve('success')
      },1000)
    })
    
    let p2 = new Promise((resolve, reject) => {
      setTimeout(() => {
        reject('failed')
      }, 500)
    })
    
    
    Promise.race([p1, p2]).then((result) => {
      console.log(result)
    }).catch((error) => {
      console.log(error)  // 打开的是 'failed'
    })
    

    相关文章

      网友评论

          本文标题:es6--Promise.all()和Promise.race(

          本文链接:https://www.haomeiwen.com/subject/ritzactx.html