• 关于Promise.all


    Promise.all() 方法接收单个可迭代对象(如数组)作为参数,并返回一个promise。每个Promise都用一个数值进行了决议,对Promise.all() 的调用创建了新的 Promise p4。这些值的存储顺序保持了待决议(resolve)的Promise顺序,与完成的先后顺序无关,因此可以将结果匹配到每个Promise。如果任意Promise被拒绝,则p4会立即拒绝,不必等其他 Promise结束。

    /* eslint-disable prefer-promise-reject-errors,eol-last */
    let p1 = new Promise((resolve, reject) => resolve(42))
    let p2 = new Promise((resolve, reject) => reject(43))
    let p3 = new Promise((resolve, reject) => resolve(44))
    
    let p4 = Promise.all([p1, p2, p3])
    let p5 = Promise.all([p1, p3])
    p1.then(v=>console.log('p1 then: ' + v)) // p1 then: 42
    p4.then(v=>console.log('p4 then: ' + v)) // 不执行
    p4.catch(v=>console.log('catch: ' + v)) // catch: 43 p2被拒绝,p4的拒绝处理函数立即调用,不会等p1和p3结束执行。但p1和p2仍然会执行。
    p5.then(v=>{
      console.log(Array.isArray(v)) // true
      console.log(v) // [ 42, 44 ]
    })
  • 相关阅读:
    js数组基础
    JavaScript原型链
    js之promise讲解
    ajax登录验证-js
    js事件委托
    js中的回调函数的理解和使用方法
    js闭包的理解
    JavaScript是如何实现继承的(六种方式)
    js创建对象的几种常用方式小结
    canvas绘图详解-08-样式填充
  • 原文地址:https://www.cnblogs.com/dodocie/p/9055240.html
Copyright © 2020-2023  润新知