ECMAScript6(15):Promise 对象

如果 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参数中的第一个回调函数࿱

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值