function promise1 = new Promise((resolve,reject)=>{ return result1 }) function promise2 = new Promise((resolve,reject)=>{ return result2 }) function promise = Promise.all([promise1(),promise2()]).then( let tree = [...result1]; tree.push(result2) ).c
先看的这篇有问题的文章 花了很长时间研究这篇文章,卡在实现串行Promise那儿了,一直看不明白.就在刚才,发现这篇文章是错的,在第一次用setTimeout( ,0)那儿就错了.虽然用setTimeout( ,0)实现了resolve的异步,但then那儿有个判断,给直接执行了,没用上这个异步.正确的代码应该是这样的 function resolve(newValue) { value = newValue; // state = 'fulfilled'; setTimeout(functio
ECMAScript6中新增了Promise对象, 所谓Promise对象,即代表着一个还未完成,但将来某时会完成的操作(通常是异步操作).使用Promise对象,我们就可以避免陷入函数层层嵌套的‘回调金字塔’里去,将异步的操作以同步的的形式展现出来.Promise对象对外提供了一整套完整的接口,方便开发者更好地控制异步操作. Promise语法 ES6的Promise对象是一个构造函数,创建一个Promise对象实例的语法如下: new Promise (function(resolve, r