es6中async中的异常处理

es6中引进了async await处理异步,我们可以在async函数中使用await使得异步函数或者promise同步化,那当我们在async函数中await了一个reject的promise的时候,async函数接下来的内容则会被跳过,如果是resolve的话,却不会这样,这真是有趣

        let count = ()=>{
    			return new Promise((resolve,reject)=>{
				reject(3);
			});
		}

		let count2 = ()=>{
			return new Promise((resolve, reject)=>{
				resolve(4);
			})
		}

		async function test(){
			let c = await count();
			let d = await count2();
			return 5;
		}

		test().then((data)=>{
			console.log(data);
		}).catch((data)=>{
			console.log(data);
		})

比如这段代码,他就会输出3

假如没有await,则会继续执行,虽然最后浏览器控制台会提示你没有catch到这个reject,比如下面这段代码会输出5

		async function test(){
			new Promise((resolve,reject)=>{reject(3);});
			//let c = await count();
			let d = await count2();
			return 5;
		}

		test().then((data)=>{
			console.log(data);
		}).catch((data)=>{
			console.log(data);
		})

那换句话说,resolve并不会阻止async函数继续执行下去。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值