promise解析

定义:

就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果

特点:

1)对象的状态不受外界的影响,Promise对象代表一个异步操作,有三种状态:pending(进行中)、fulfilled(已成功)、rejected(已失败)
2)一旦状态改变,就不会再变,任何时候都可以得到结果。

缺点:

1):一旦新建它就会立即执行,无法中途取消,
2)如果不设置回调函数,promise 内部,抛出的错误,不会反应到外部,
3)当处于pending状态时,无法得知目前进展到哪一个阶段

promise 的状态结果:

一共有两种:

  • pending(初始化) 到 成功 及 fulfilled
  • pending(初始化) 到 失败及reject

状态一旦改变之后 就不可以再 变化了

  let p =   new Promise(function (resolve, reject) {
            //resolve 成功
            //reject 失败
            $.ajax({
                    url:'请求的接口',
                    success:function(res){
                    // http状态码是200
                       resolve(res)
                    },
                    error:function(err){
                        // http状态码是其他
                        reject(err)
                    }
                }) 
        })

axios 就是基于promise原理实现的

作用:

promise 可以解决复杂的异步依赖 (异步套异步) 去解决地狱回调,死亡循环

setTimeout(function () {
                    setTimeout(function () {
                        setTimeout(function () {
        
                        }, 1000)
                    }, 1000)
                }, 1000)

大量的异步嵌套 代码结构复杂混乱 不利于后期修改

解决地狱回调问题

 function timer(count) {
        var p = new Promise((resolve, reject) => {
            setTimeout(() => {
                //console.log(1)
                //resolve(count)
                reject(count)
            }, 1000)
        })
        return p
    }
    timer('1')
        .then((res)=>{
            console.log(res)
            return timer('2')
        })
        .then((res)=>{
            console.log(res)
            return timer('3')
        })
        .then((res)=>{
            console.log(res)
            return timer('4')
        })
        .then((res)=>{
            console.log(res)
        })
        .catch((err)=>{
            console.log(err)
        })

promiseAPI

Promise.all()

  • Promise.all() 可以把多个promise实例 整合成一个新的promise实例 这里面也会调取成功和失败 但是有一点不同
    成功的时候数据会以数组的形式出现 失败的时候 不管是否成功 都直接输出失败
  • 成功的时候 数据以数组形式出现 例:[“成功咯”, “又成功咯”] 实例位置变化 会导致输出结果的变化
     let p1 = new Promise((resolve,reject)=>{
            resolve('成功咯')
        })
        let p2 = new  Promise((resolve,reject)=>{
            resolve('又成功咯')
        })
        let p3 = Promise.reject('很遗憾,挂了') 

        Promise.all([p1,p2])
        .then((res)=>{
            console.log(res,'res')  //成功的时候  数据以数组形式出现["成功咯", "又成功咯"] 实例位置变化 会导致输出结果的变化
        })
        .catch((err)=>{
            console.log(err,'err')
        }) 

        Promise.all([p1,p3,p2])
        .then((res)=>{
            console.log(res,'res带失败的')
        })
        .catch((err)=>{
            console.log(err,'err失败的') //有失败的情况 直接走失败的内容 不会输出任何成功信息
        }) 

Promise.race()

  • Promise.race() 赛跑的意思 顾名思义 谁先执行完 谁就先输出 与位置无关
  • 它这个方法 不管成功还是失败 都可以输出来 然后 输出的顺序 按照 谁先执行完 谁先输出来
    function timer(msg,count){
        let p = new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve({code:200,msg})
            },count)
         })
        return p
     }
     let p4 = timer('我是p4',6000).then((res)=>{
         console.log(res)
    })
    let p5 = timer('我是p5',5000).then((res)=>{
        console.log(res)
     })
     Promise.race([p5,p4]) 

它这个方法 不管成功还是失败 都可以输出来 然后 输出的顺序 按照 谁先执行完 谁先输出来

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Promise是一种用于处理异步操作的对象。它可以将异步操作封装成一个可控的对象,使得在异步操作完成后能够根据操作结果执行相应的操作。 在使用Promise时,可以通过实例化Promise对象来创建一个Promise实例。Promise实例接收一个参数函数,该函数包含异步操作的代码。在异步操作成功时,可以调用resolve方法来返回操作结果;在异步操作失败时,可以调用reject方法来返回错误信息。 Promise提供了两种写法来处理异步操作的结果。一种是使用then和catch方法来分别处理操作成功和失败的情况。另一种是使用传统的回调函数的方式,将操作成功和失败的回调函数作为参数传递给then方法。 需要注意的是,在调用resolve或reject之后,Promise的使命就完成了,最好在它们前面加上return,以避免产生意外。另外,resolve或reject的调用并不会终结Promise的参数函数的执行。 除了处理单个异步操作外,Promise还可以用于容错。比如,可以使用Promise.race()方法来同时处理多个异步任务,并获得先返回的结果。 综上所述,Promise是一种用于处理异步操作的对象,可以通过实例化Promise对象来创建一个Promise实例,并使用then和catch方法或传统的回调函数的方式来处理异步操作的结果。另外,Promise还提供了Promise.race()方法用于同时处理多个异步任务并获得先返回的结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Promise对象解析及其用法](https://blog.csdn.net/SummerJX/article/details/81948818)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值