async & await

9 篇文章 0 订阅

async & await

简介

async:异步,用于定义函数为异步函数,定义的异步函数返回一个promise

await:等待,等待promise执行resolve

ES2017之前处理异步一般都是promise,之后加入了async & await

async & await本身时建立在promise的基础上,所以要更好的理解async & await需要清楚promise工作方式

let a = async () => {
	return await new Promise((resolve) => {
		setTimeout(() => {
			resolve('hello ')
		}, 100)
	})
}

let b = async () => {
	return 'world'
}

let all = async () => {
	let resA = await a()
	let resB = await b()
	resA += resB
	return resA
}
all().then(console.log)
// 输出结果:
// hello world

为什么使用async & await

  • 突破的promise中.then().then()…的链条
  • 语法上看起来更像同步操作
  • 在开发过程中更方便调试异步代码,promise会跳过异步代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bdawn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值