Promise(二)对象状态、结果值属性介绍、工作流程、API以及几个关键问题

四、Promise对象状态、结果值属性介绍

1、实例对象中的一个属性 【promiseState】
  1. pending 未决定的

  2. resolved / fullfiled 成功

3)rejected 失败

*状态改变只能由pending->resolved 或者pending->rejected

2、Promise 对象的值

实例对象中的另一个属性 【PromiseResult】

保存着异步任务【成功/失败】的结果

  • resolve
  • reject

五、Promise的基本流程

六、 如何使用Promise?

1、API

  1. Promise构造函数:promise(excutor){}
  • executor函数:执行器(resolve,reject)=>{}
  • resolve函数:内部定义成功时调用函数 value=>{}
  • reject函数:内部定义失败时调用函数reason=>{}

ps:executor会在Promise内部立即同步调用,异步操作在执行器中执行

2) Promise.prototype.then方法:(onResolved,onRejected)=>{}

  • onResolved函数:成功的回调函数 value=>{}
  • onRejected函数:失败的回调函数 reason=>{}

ps:指定用于得到成功value的成功回调函数和用以得到失败reason的失败回调返回一个新的promise对象

3)Promise.prototype.catch 方法:(onRejected)=>{}

  • onRejected函数:失败的回调函数 reason=>{}
  1. Promise.resolve方法:(value)=>{}
  • value:成功的数据或promise对象

ps:返回一个成功/失败的promise对象

5)Promise.reject方法:(reason)=>{}

  • reason:失败的原因

ps:返回一个失败的promise对象

6)Promise.all方法:(promises)=>{}

  • promises:包含n个promise的数组

ps:返回的一个新的promise,只有所有的promise都成功才成功,只要有一个失败了就直接失败

<script>
    let p1 = new Promise((resolve, reject) => {
        resolve('ok');
    });
    let p2 = Promise.resolve('Success');
    // let p2 = Promise.reject('Error');
    let p3 = Promise.resolve('yes');
    const  result = Promise.all([p1,p2,p3]);
    console.log(result);//fullfiled   rejected
</script>

7)Promise.race方法:(promises)=>{}

  • promises:包含n个promise的数组

ps:说明返回一个人新的promise,第一个完成的promise的结果状态就是最终的结果状态

<script>
    let p1 = new Promise((resolve, reject) => {
        setTimeout(()=>{
            resolve('ok');
        },1000)
    });
    let p2 = Promise.resolve('Success');
    // let p2 = Promise.reject('Error');
    let p3 = Promise.resolve('yes');
    const  result = Promise.race([p1,p2,p3]);
    console.log(result);//p2第一个完成
</script>

2、promise的几个关键问题

1)如何修改对象的状态? resolve(),reject(),throw

<script>
    let p = new Promise((resolve, reject) => {
        //1、resolved 函数
        // resolve('ok');//pending => fulfilled(resolved)
        //reject 函数
        // rejected('error');//pending => rejected
        // 3.抛出错误
        throw '出问题了'
    });
    console.log(p);
</script>
  1. 一个promise指定多个成功/失败回调函数,都会调用吗?

    当promise改变为对应状态时会调用

<script>
    let p = new Promise((resolve, reject) => {
        resolve('ok');//promise的状态从pending->resolved,执行相应的回调函数
    });
    //指定回调 -1
    p.then(value=>{
        console.log(value);
    });
    //指定回调 -2
    p.then(value => {
        alert('value')
    })
</script>

3)改变promise状态和指定回调函数谁先谁后?

都有可能,正常情况下时先指定回调再改变状态,但是也可以先改变状态再指定回调

  • 如何先改变状态再指定回调?

    1.在执行器中直接调用resolve/reject()

    2.延迟更长时间才调用then()

  • 什么时候才能得到数据?

    1.如果先指定回调,那当状态发生改变时,回调函数就会调用,得到数据

    2.如果先改变状态,那当指定回调时,回调函数就会调用,得到数据

4)then方法的返回结果由什么决定?

	由then方法指定的回调函数的结果决定

5)串联多个操作任务

- promise的then返回一个新的promise,可以看出then的链式调用
- 通过then的链式调用串联多个同步/异步任务
<script>
    let p = new Promise((resolve, reject) => {
        setTimeout(()=>{
            resolve('ok');
        },1000);
    });
    p.then(value =>{
        return new Promise((resolve, reject) => {
            resolve('success');
        });
    }).then(value => {
        console.log(value);//success
    }).then(value => {
        console.log(value);//undefined
    })
</script>
  1. 异常穿透

由最后的catch方法实现错误处理

 let p = new Promise((resolve, reject) => {
        setTimeout(()=>{
            resolve('ok');
            // reject('Err');
        },1000);
    });
    p.then(value=>{
        console.log(111);
        throw '出错了!';
    }).then(value => {
        console.log(222);
    }).then(value => {
        console.log(333);
    }).catch(reason => {
        console.warn(reason);
    })
  1. 中断promise链
  • 当使用promise的then链式调用时,在中间中断,不再调用后面的回调函数
  • 办法:在回调函数中返回一个pendding状态的promise对象
 return new Promise(()=>{});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值