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

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...