0
点赞
收藏
分享

微信扫一扫

JS 关于async和await的注意项

infgrad 2022-03-30 阅读 80
javascript

一、async

async关键字修饰的函数,其返回值被Promise对象修饰,等价:Promise.resolve(返回值)。

async function a() {
	return 1;
}

//等价
function a() {
	return Promise.resolve(1);
}

async关键字修饰的函数没有返回值时,等价Promise.resolve();

二、await

await用于等待一个Promise 对象。它只能在异步函数 async function 中使用,等待Promise的回调执行完成,再执行下一条语句。await会获取所修饰的Promise对象resolve()的值,reject()的值会通过异常抛出

async function a() {
	//正常获取
	let data  = await Promise.resolve(1)
	//data == 1
	
	//异常抛出
	try {
    	let err = await Promise.reject(30);
	} catch (e) {
    	console.log(e); // 30
  	}
}

await用于修饰一个非Promise 对象时,返回所修饰的表达式的值,不会等待异步、耗时的表达式操作的完成

三、Promise.then()方法返回一个 Promise。它最多需要有两个参数:Promise 的成功和失败情况的回调函数

async和await关键字让我们可以用一种更简洁的方式写出基于Promise的异步行为,而无需刻意地链式调用promise。

//语法
p.then(onFulfilled[, onRejected]);
Promise.then(value => {
  // fulfillment
}, reason => {
  // rejection
})
举报

相关推荐

0 条评论