promise介绍

  • promise 是什么
    • promise是异步编程的一种解决方案,比传统的回调函数和事件处理的更加合理和强大。
    • 是一个容器,里面保存着某个未来才会结束的事件的结果。
  • 参数
    • resolve
      • 将promise对象的状态从“未完成”变为“完成”,在异步操作成功时调用,并将异步操作的结果,作为参数传递出去
    • reject
      • 将Promise对象的状态从“未完成”变成“失败”,在异步操作失败时调用,并将异步操作报出的错误作为参数传递出去
  • 使用(处理一个任务)
    • 用 then 方法分别指定 resolved 状态和 rejected 状态的回调函数
    • 例如
    promise.then(function(value){
        //success
    }).catch(function(err){
        //fail
    })
  • 使用(串行多个任务)
    • job1.then(job2).then(job3).catch(handleError)
  • 使用(并行多个任务)
    • 用Promise.all()实现
    var p1 = new Promise(function (resolve, reject) {
        setTimeout(resolve, 500, 'P1');
    });
    var p2 = new Promise(function (resolve, reject) {
        setTimeout(resolve, 600, 'P2');
    });
    // 同时执行p1和p2,并在它们都完成后执行then:
    Promise.all([p1, p2]).then(function (results) {
        console.log(results); // 获得一个Array: ['P1', 'P2']
    });
  • 使用(并行多个任务,只需获得先返回的结果)
    • 用Promise.race()实现
    var p1 = new Promise(function (resolve, reject) {
        setTimeout(resolve, 500, 'P1');
    });
    var p2 = new Promise(function (resolve, reject) {
        setTimeout(resolve, 600, 'P2');
    });
    Promise.race([p1, p2]).then(function (result) {
        console.log(result); // 'P1'
    });
  • 由于p1执行较快,Promise的then()将获得结果’P1’。p2仍在继续执行,但执行结果将被丢弃。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值