如果 resolve 的参数是一个promise:
var p1 = new Promise(function(resolve, reject){
//…
});
var p2 = new Promise(function(resolve, reject){
//…
resolve(p1);
});
上面代码中 p1 的状态传给了 p2,也就是p1运行完成(状态为 resolve 或 reject)后 p2 的回调函数会立刻开始执行:
var p1 = new Promise(function(resolve, reject){
setTimeout(() => reject(new Error(‘failed’)), 3000);
});
var p2 = new Promise(function(resolve, reject){
setTimeout(() => resolve(p1), 1000);
});
p2.then(result => console.log(result));
p2.catch(error => console.log(error));
p1 建立,进入 setTimeout 异步计时器。之后 p2 建立,进入 setTimeout 异步计时器。1s 后 p2 准备执行 resolve, 但是 resolve 的参数是 p1, 此时 p1 还是 Pending 状态,所以 p2 开始等待。又过了 2s, p1 的 reject 执行,变为 rejected 状态,随即 p2 也跟着变成 rejected 状态。
Promise 对象方法
- then() 方法
then(resolve(value){},reject(value){})
方法接受2个函数参数,resolve 在 Promise 状态变为 resolved 时调用,reject 在 Promise 状态变为 rejected 时调用。其中 reject 参数是可选的。和构造函数不同的是,then 方法的 reject 和 resolve 都使用 promise 传出的值作为其唯一的参数。
then()
方法返回一个新的 Promise 实例,注意,不是之前那个。因此可以用链式调用,不断添加”回调”函数。 then 的返回值成了下一个 then 中回调函数的参数:
var p = new Promise(function(resolve, reject){
resolve(“from new Promise”);
}).then(function (value){
console.log(value); //from new Promise 其次输出这个
return “from the first ‘then’”;
}).then(function(value){
console.log(value); //from the first ‘then’ 最后输出这个
return “from the second ‘then’”;
});
console.log§; //Promise{…} 先输出这个
注意,如果 promise 的状态是 resolved 则执行 then参数中的第一个回调函数