ES6:ES6的Promise考点(*****五颗星)

1.Promise的基本语法

<script>
	//假设: flag是ajax的返回状态
	let flag=false;
	let p=new Promise((resolve,reject)=>{
		if(flag){
			resolve("传参res")//pending-->fulfilled  异步操作成功的回调函数
		}else{
			reject("传参err")//pending-->rejected     异步操作失败的回调函数
		}
	})
	p.then(res=>{//在外面调用then处理成功的逻辑回调,fulfilled
		console.log(res)//传参res,res是成功时候抛出/打包/暴露的数据
	}).catch(err=>{//在外面调用catch处理失败的逻辑回调,rejected
		console.log(err)//传参err,err是失败时候暴露的异常信息
	})
</script>

注意:promise本身是同步的,但是.then和.catch是异步的

2.Promise三个状态

***默认状态----pending     悬而未决的

            ***成功状态----fulfilled   满足了

            resolve();// pending----->fulfilled

            ***失败状态----rejected    拒绝,不开心了

            reject();// pending----->rejected

三个状态的特点:

1. 状态不受外部影响  

2. 状态一旦发生改变将不再变化(已凝固)

3.Promise解决jquery ajax回调地狱

如何解决回调地狱----将异步代码改成看起来像同步代码(方便维护)

jquery CDN参考链接:https://developer.aliyun.com/article/944826

//引入jquery库,如果您不希望下载并存放 jQuery,那么也可以通过 CDN(内容分发网络) 引用它。 Staticfile CDN、百度、又拍云、新浪、谷歌和微软的服务器都存有 jQuery 。 如果你的站点用户是国内的,建议使用百度、又拍云、新浪等国内CDN地址,如果你站点用户是国外的可以使用谷歌和微软。 如需从 Staticfile CDN、又拍云、新浪、谷歌或微软引用 jQuery,
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
	        //promise解决jquery ajax回调地狱
            let p1=new Promise((resolve,reject)=>{
           $.ajax({
               url:"./test.txt",
               type:"GET",
               success(res){
                   resolve(1)
               },
               error(err){
                   reject(err)
               }
           })
        })       
        let p2=new Promise((resolve,reject)=>{
           $.ajax({
               url:"./test1.txt",
               type:"GET",
               success(res){
                   resolve(2)
               },
               error(err){
                   reject(err)
               }
           })
         })
        let p3=new Promise((resolve,reject)=>{
           $.ajax({
               url:"./test2.txt",
               type:"GET",
               success(res){
                   resolve(3)
               },
               error(err){
                   reject(err)
               }
           })
         })
        p1.then(res=>{
           console.log(res)
           return p2
        }).then(res=>{
           console.log(res)
           return p3
        }).then(res=>{
           console.log(res)
        }).catch(err=>{
           console.log(err.responseText)
            })
</script>

4.Promise解决多重请求函数封装

<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
        /* 
            ajax请求的是本地文件,则Status Code: 304 OK
            HTTP 304 Not Modified 说明无需再次传输请求的内容,也就是说可以使用缓存的内容。
            这通常是在一些安全的方法(safe),例如GET 或HEAD 或在请求中附带了头部信息: If-None-Match 或If-Modified-Since。
            如果是 200 OK ,响应会带有头部 Cache-Control, Content-Location, Date, ETag, Expires,和 Vary.
        */
        function getPromiseObj(url,type,num){
            return new Promise((resolve,reject)=>{
                $.ajax({
                    url,
                    type,
                    success(res){
                        resolve(num)
                    },
                    error(err){
                        reject(err)
                    }
                })
            })
        }
        let p1=getPromiseObj("./test.txt","GET",1)
        let p2=getPromiseObj("./test1.txt","GET",2)
        let p3=getPromiseObj("./test2.txt","GET",3)
        p1.then(res=>{
            console.log(res)
            return p2
        }).then(res=>{
            console.log(res)
            return p3
        }).then(res=>{
            console.log(res)
        }).catch(err=>{
            console.log(err.responseText)
        })
    </script>

5.Promise两个方法:.all()和.race()

1. Promise.all([多个Promise对象])

Promise.all([多个Promise对象])  ---- 统一处理多个异步程序(定时器,时间可控)----类似&&的关系

        场景: 页面一进来,就要加载三个ajax,只有三个全部成功,才可以渲染页面

            语法:

            1.1 如果多个异步程序都是成功状态, p的状态就是成功, 多个异步程序的成功结果会打包成一个数组统一返回

            1.2 但凡发现一个失败,最快得到失败结果的直接返回

      声明一个对象p 接受三个异步程序的结果

        如:let p = Promise.all([p1,p2,p3]); // 这是代码,你试一下切换状态!!!

2. Promise.race([多个Promise对象])

Promise.race([多个Promise对象]) ----- 类似 ||,谁快返回谁, 不分成功还是失败

如:let p=Promise.race([p1,p2,p3])

<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
       let p1=new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve("成功1")
                // reject("失败1")
            },3000)
       })
       let p2=new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve("成功2")
                // reject("失败2")
            },2000)
       })
       let p3=new Promise((resolve,reject)=>{
            setTimeout(()=>{
                // resolve("成功3")
                reject("失败3")
            },1000)
       })
       let pAll=Promise.all([p1,p2,p3])
       let pRace=Promise.race([p1,p2,p3])
       pAll.then(res=>{
            console.log(res+" all()")//如果p1,p2,p3是fulfilled状态,则['成功1', '成功2', '成功3']
       }).catch(err=>{
            console.log(err+" all()")//当只有p3是rejected状态,p1,p2是fulfilled状态,则失败3
       })
    //  
       pRace.then(res=>{
            console.log(res+" race()")//
       }).catch(err=>{
            console.log(err+" race()")//因为p3返回快,所以失败3
       })
    </script>

6.promise异步代码同步化

async函数和await关键字一般成对出现,当函数执行的时候,一旦遇到await就会先返回,等到异步操作完成,再接着执行函数体内后面的语句。

需求: p1  p2   p3 三个ajax异步程序 顺序执行(同步代码执行顺序),代码如下:

        async  await  一组关键字

        重点(项目中要用)*****

        async 用来修饰函数,表示这是一个异步函数

        await 在异步函数中使用,表示同步代码(异步程序变成同步代码)

         ------await后面的异步执行完毕才会执行后续的同步代码

<script>
        // 使用定时器模拟ajax ,  时间就是响应成功的时间
        let p1=new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve("成功1")
            },3000)
        })
        let p2=new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve("成功2")
            },2000)
        })
        let p3=new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve("成功3")
            },1000)
        })
        async function getVal(){
            await p1.then(res=>console.log(res))
            await p2.then(res=>console.log(res))
            await p3.then(res=>console.log(res))
		  
		  console.log("同步")
        }
        getVal()//结果:成功1,成功2,成功3,同步
    </script>

7.总结

Promise目标就是解决一部程序的回调地狱问题

如何解决回调地狱----将异步代码改成看起来像同步代码(方便维护)

想看更多面试题可订阅下方的专栏或点击链接即可订阅

前端面试题 文章被收录于专栏

前端面试的一些常问问题、问题的具体实现(可直接运行)以及底层原理

全部评论
可订阅下方的专栏有更多的面试干货
1 回复 分享
发布于 2023-03-04 18:07 四川
感谢大佬的分享鸭!
1 回复 分享
发布于 2023-02-14 12:30 辽宁
进来狠狠学习了!
1 回复 分享
发布于 2023-02-14 12:24 辽宁

相关推荐

2025-12-27 16:21
已编辑
门头沟学院 Java
bg:中下211本科,java后端,无竞赛,无基础,大一升大二暑假开始学java。五段实习:美团-小红书-腾讯-淘天-字节。面秋招的简历只有美团、小红书、淘天。刚刚发现我的秋招蚂蚁流程挂了,这是我最后一个流程,那么我的秋招就算彻底结束了,总结一下:字节ssp+,职级2-1。美团ssp,+2打了半小时微信电话极力挽留。快手ssp,但报了字节薪资后没有争取的想法了。小红书sp,今年小红书给的很高,但比字节2-1还是差很多。虾皮应该是小sp?对虾皮一点意向都没,纯拿来集邮了。淘天ssp(暑期转正),说不要我的三方,毕业前考虑好了随时可以不签三方选择淘天。挂了的流程:京东二面挂,估计学历被卡了。懂车帝一面挂,和面试官聊不来,不认同我的方案。拼多多hr面挂,问我低于预期还来不来,当时说不考虑了,估计觉得我不忠诚。蚂蚁hr面挂,聊的还行,但估计我不会去给我挂了吧。阿里控股一面挂,没面前就知道是kpi了,因为时间可选的很多,而且都是半小时,我也拿他刷我的kpi了。上面差不多是我的情况,下面是我想说的话。我觉得我不算特别突出优秀的那类人,但我多少也算是靠前的那一批人,即使这样,秋招也不算特别顺利,也有挂了的流程,但你能说是我的问题吗,我觉得大部分情况不是的,如果真的是我的问题,我不可能本科校招拿到2-1,所以很多面试挂了,问题不出在面试者身上,很多是看运气+眼缘+和面试官合不合得来。所以我觉得,学会察言观色,了解面试官的脾性,也是面试很重要的一个点。比如面试官是喜欢听长回答,还是听短回答,他更看重哪些点,每个面试官对这些的侧重都是不一样的,所以作为面试者,要学会察言观色,通过面试官开局的一两个问题以及你回答后他的表现,就要判断出来。像我现在其实面试开局个五分钟,我就基本能判断个七七八八了,然后我后面的回答就会有所变化。这是我想说的第一个点:不要为面试结果焦虑,有时候问题不出在你身上,但你可以学一些面试技巧,尽量提高你的面试通过率,这里说的面试技巧指的不是网上那种烂大街的,一两分钟短视频说什么提高你面试通过率的,而是你要在你自己的面试过程中不断总结经验,吸取教训,旁人教你的终究是有限的。另外想说下选offer的事,上面其实可以看出来,我秋招最后是选了字节的,还没签三方我就来提前实习感受业务了,当我签完三方又过了一个多月,我这些天又在想这个问题,字节真的是我想要的吗,我现在总结了一下字节的好坏,发现当时可能被字节的高薪资影响判断了,如果现在再选一次的话,我应该会选杭州的小红书,会生活的更舒服点。具体种种就不展开说了。然后虽然我现在也可以说去把小红书舔回来,去毁字节,但我觉得没必要这么做,我可以采用其他的措施去不就,比如规划好两年内就跳槽,跳到杭州,跳到更舒适的城市。我觉得大家选offer的时候,真的可以冷静下来多方面考虑,薪资、城市、组内氛围、业务、老板是否看重、组内情况、未来升职机会等等都是可以考虑的因素,虽然有的时候不管选哪个,都不会坏,但最好也别让自己后悔吧,即使真后悔了,我觉得也没必要过度美化没走过的路,想好补救措施即可。这是我想说的第二个点:冷静好好做选择,不管是offer还是其他。但人生容错率很大,即使选错了,也一定有补救措施。最后还想说一些成长上的东西,尤其是现在AI火热的时代。我觉得大家如果想提高自己,或者说在未来社招跳槽有竞争力,肯定是要学AI相关的东西的,不说要会多懂AI,至少也要了解基本概念,而且一定要学会用AI提效。我现在字节的mt和我说,他现在80%代码都是AI写的。而我最近也开始尝试用AI工具,感觉现在AI真的进步很多,挺聪明的了,我现在写需求基本都是先让AI写,我再人工review小改动一下就差不多了。我觉得「AI取代程序员」是个很远的话题,但是「AI取代不会用AI的程序员」,可能真的就是近两年的事了。而怎么去学习这块的内容,其实我也正在探索,我也是刚学AI的起步阶段,我觉得大家也要有自己的信息检索能力,而不是别人喂你什么,你才学什么,自己一个人就不会学了。这是我想说的第三个点:趁年轻,多学习提升自己,拥抱AI,不要原地踏步,原地踏步的程序员最容易被淘汰。大概就是这样吧,今天看蚂蚁流程发现挂了,前几天腾讯约面我也拒了,就想到自己的秋招/校招算彻底结束了,有感而发,随便聊了下。牛客以后应该不会更新,大家不用关注,熟悉我的朋友应该知道我在其他平台有号。我更喜欢以长视频的形式去做分享,感觉会更有体系,而不是网上那种一两分钟的零碎短视频的那种营销号去起号,我也推荐大家多去看高质量的长文章、长视频,我觉得收获的能更多。希望大家能收获满意的offer与未来。
CEXBB:刷到最后才发现原来是优雅✌🏻,我的Java引路人
2025年终总结
点赞 评论 收藏
分享
评论
32
330
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务