Promise

目录

基本格式:状态和方法

promise实例使用then方法后任然是一个promise,可以继续调用then

 catch处理错误的,reject

promise对象的简写

promise.resolve()

promise.reject()

管理多个promise对象

promise.all()

promise.race()

promise.allSettle()

注意事项

传入的参数,要是可以迭代的对象,如果不是promise,会自动转化为promise对象

管理多个promise对象,出现错误


promise的产生是为了解决回调地狱的问题。promise是一个对象,有属性和方法。

基本格式:状态和方法

一个promise实例有三个状态:pending(等待),resolve(成功解决),resolved(成功解决后)。

或者pending(等待),reject(失败),rejected(失败后)。

promise有then方法,可以通过resolve和reject传给then数据,resolve和reject里面存放数据。

<script>
        // promise书写的格式,一个promise要经历三个状态,pending ,resolve ,reject
        const a =new Promise((resolve,reject)=>{
            // 执行resove后就是resolved状态
            resolve("传给then");
            // 执行reject后就是rejected状态
            // reject();
        });
        // 返回的也是一个promise对象,因此也可以继续调用then方法
        a.then(
            // 当是resolve()执行的时候,就显示secucess

            (data)=>{
                console.log("secucess",data);
            },
            ()=>{
                console.log("error");
            },

        )
    </script>

promise实例使用then方法后任然是一个promise,可以继续调用then

上一个then控制下一个then,默认下一个then执行成功

    <script>
        // promise书写的格式,一个promise要经历三个状态,pending resolve ,reject
        const a =new Promise((resolve,reject)=>{
            // 执行resove后就是resoved状态
           resolve("传给then");
            // 执行reject后就是rejected状态
            // reject();
        });
        // 返回的也是一个promise对象,因此也可以继续调用then方法
        a.then(
            // 当是resove()执行的时候,就显示secucess

            (data)=>{
                console.log("secucess",data);
                // 默认
                // return undefined;
                // 等价于 ,前面一定要加new
                return new Promise(reject=>{
                    // resove();
                    reject();

                })
            },
            ()=>{
                console.log("error");
            },

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值