JS高级:Proxy-Reflect-Promise(一)_独憩的博客-CSDN博客
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方法传入的回调函数有返回值时,进行决议
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
就是不管结果是什么都会执行的代码,且是放在最后执行的
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是更方便的
const a =[12]Promise.resolve(a).then((value)=>{console.log(value);})
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就会直接拒绝
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);})
五秒后输出
竞赛的意思,既谁先有结果就用谁,不管是什么结果
Promise.race([p1,p2,p3]).then((a)=>{console.log(a);}).catch((err)=>{console.log('jujue',err);})
两秒之后输出 jujuep33
输出第一个接受的结果
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