JS高级:Promise(二)
创始人
2024-03-30 12:51:50
0

JS高级:Proxy-Reflect-Promise(一)_独憩的博客-CSDN博客

then方法的返回值

    const promise = new Promise((reslove,reject)=>{reslove(111)})promise.then((value)=>{console.log('成功',value);}).then(value =>{console.log('成功2',value);})

也就是说第二个then可以运行,但是没有参数值

那是因为第一个then的返回值就是一个新的promise,但是没有决议,也就说第二个then的对象是第一个then之后返回的新的promise

可以给第一个then确定一个返回值

    const promise = new Promise((reslove,reject)=>{reslove(111)})promise.then((value)=>{console.log('成功',value);return 2222}).then(value =>{console.log('成功2',value);})

then方法返回一个新的promise,这个新的promise的决议是等到then方法传入的回调函数有返回值时,进行决议

 catch方法的返回值

    const promise = new Promise((reslove,reject)=>{reject(111)})promise.then((value)=>{console.log('成功',value);return 2222}).then(value =>{console.log('成功2',value);}).catch(err=>{console.log('错误',err);})

这里会直接输出  错误:111

因为第一个promise就拒绝了,所以在调用时会寻找最近的catch进行调用,而不会执行then

但是我希望在第一个promise接收时,第二个then拒绝,就可以运行catch了,那么可以在then中返回一个错误

    const promise = new Promise((reslove,reject)=>{reslove(111)})promise.then((value)=>{console.log('成功',value);return 2222}).then(value =>{console.log('成功2',value);throw new Error('aaa错啦')}).catch(err=>{console.log('错误',err);})

这里第一个promise接收,所以会调用第一个then,然后第一个then返回的新promise也接受,返回2222,调用第二个then,第二个then拒绝,返回一个错误,调用catch

 

finally

就是不管结果是什么都会执行的代码,且是放在最后执行的

    const promise = new Promise((reslove,reject)=>{reslove(111)})promise.then((value)=>{console.log('成功',value);return 2222}).catch(err=>{console.log('错误',err);}).finally(()=>{console.log('结束了');})console.log('jieshule');//会首先执行,不行

这个地方我直接在外部放代码是不行的,因为它会首先执行,所以finally是更方便的

 resolve类方法

 

    const a =[12]Promise.resolve(a).then((value)=>{console.log(value);})

all类方法

 

 

    const p1 = new Promise((resolve,reject)=>{setTimeout(()=>{resolve('p11')},3000)})const p2 = new Promise((resolve,reject)=>{setTimeout(()=>{resolve('p22')},5000)})const p3 = new Promise((resolve,reject)=>{setTimeout(()=>{resolve('p33')},2000)})Promise.all([p1,p2,p3]).then((res)=>{console.log(res);}).catch((err)=>{console.log(err);})

五秒之后输出: 

将 p3改为

    const p3 = new Promise((resolve,reject)=>{setTimeout(()=>{reject('p33')},2000)})

 两秒后输出

 

当所有promise都接受的时候才接受Promise.all,如果出现一个promise拒绝,就会Promise.all就会直接拒绝

allSettled类方法

 

    const p1 = new Promise((resolve,reject)=>{setTimeout(()=>{resolve('p11')},3000)})const p2 = new Promise((resolve,reject)=>{setTimeout(()=>{resolve('p22')},5000)})const p3 = new Promise((resolve,reject)=>{setTimeout(()=>{reject('p33')},2000)})Promise.allSettled([p1,p2,p3]).then((a)=>{console.log(a);}).catch((err)=>{console.log(err);})

五秒后输出

 race方法

竞赛的意思,既谁先有结果就用谁,不管是什么结果

    Promise.race([p1,p2,p3]).then((a)=>{console.log(a);}).catch((err)=>{console.log('jujue',err);})

两秒之后输出  jujuep33

any方法

输出第一个接受的结果

    Promise.any([p1,p2,p3]).then((a)=>{console.log(a);}).catch((err)=>{console.log('jujue',err);})

三秒之后输出p11

如果p1,p2,p3都没有接受,就会执行catch    输出 jujue AggregateError: All promises were rejected

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...