当前位置:网站首页>Promise(一)
Promise(一)
2022-04-23 05:56:00 【画不完的饼】
Promise的三种状态
1.pending
2.resolved
3.rejected
三种状态关系
pending -> resolved (可以转换)
pending -> rejected (可以转换)
<script>
const p1 = new Promise((resolve, reject) => { //创建promise
})
console.log(p1)
// pending=>resolved
const p2 = new Promise((resolve, reject) => { //创建promise2
resolve()
})
console.log(p2)
// pending=>reject
const p3 = new Promise((resolve, reject) => { //创建promise3
reject()
})
console.log(p3)
</script>
Promise不同状态表现
//pending状态下的promise不会触发then 和catch
const p1 = new Promise((resolve, reject) => { //创建promise
})
console.log(p1)
p1.then(()=>{
console.log('p1 then')
}).catch(()=>{
console.log('p1 catch')
})
//resolve状态下的promise会触发then里面的回调函数
const p2 = Priomise.resolve() //简写
p2.then(()=>{
console.log('p2 then')
}).catch(()=>{
console.log('p2 catch')
})
//reject状态下的promise会触发catch 里面的回调函数
const p3 = Promise reject()
p3.then(()=>{
console.log('p3 then')
}).catch(()=>{
console.log('p3 catch')
})
then、catch对Promise状态的影响
const p1 = Promise.resolve()
console.log(p1)
//p1.then的回调函数里面没有抛出异常,所以,会返回一个resolve
const res = p1.then(()=>{
console.log('success')
})
//p1.then的回调函数里面抛出异常,所以,会返回一个reject
const res = p1.then(()=>{
throw new Error('error')//这里我抛出一个异常
})
//p1.catch的回调函数里面没有抛出异常,所以,会返回一个resolve
const res = p1.catch(()=>{
console.log('success')
})
//p1.catch的回调函数里面抛出异常,所以,会返回一个reject
const res = p1.catch(()=>{
throw new Error('error')//这里我抛出一个异常
})
总结:无论then || catch 有没有抛出异常,p.then或者p.catch都会返回一个resolve状态的Promise。如果抛出异常,p.then或者p.catch都会返回reject状态的Promise。
版权声明
本文为[画不完的饼]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_39162041/article/details/124192644
边栏推荐
猜你喜欢
随机推荐
锚点定位——如何设置锚点居页面顶部距离,锚点定位并距离顶部一定偏移
1-3 NodeJS的安装之清单配置与跑项目环境
ASP.NET CORE 配置选项(上篇)
如何使用input表单向服务发送(占用较小)图片文件(body传输)?涉及到FileReader内置对象
查漏补缺(二)
Assembler 32-bit unsigned addition calculator
.Net Core3.1 使用 RazorEngine.NetCore 制作实体生成器 (MVC网页版)
说说ts的心里话
监听除某元素之外点击事件
获取当前一周的时间范围
JS实现私有属性
1-4 NodeJS的安装之配置可执行脚本
js根据名字将数组对象中名字相同的项组成一个相同的数组
WebAPI+Form表单上传文件
几款笔记软件的优缺点
Node模版引擎(ejs, art-template)
Devexpress Gridview 添加全选列
查漏补缺(六)
查漏补缺(九)---程序篇
Mysql中的索引与视图









