async await js中
时间: 2024-07-05 21:00:57 浏览: 164
`async/await` 是JavaScript的异步编程特性,由`async`关键字引入的函数允许我们以同步的方式编写异步代码,通过`await`关键字等待异步操作完成。具体来说:
1. **async函数**:`async`关键字定义了一个异步函数,它返回的是一个Promise。这意味着函数内部的代码可以使用`await`关键字暂停执行,直到Promise解析或拒绝。
2. **await关键字**:当你在`async`函数中遇到`await`时,它会暂停当前任务(函数执行),直到调用的异步操作(如`Promise`或`async`函数)完成。当操作完成后,`await`后面的表达式会得到操作的结果。
例如:
```javascript
async function fetchData() {
try {
const response = await fetch('https://api.example.com/data');
const data = await response.json();
return data;
} catch (error) {
console.error(error);
}
}
```
在这个例子中,`fetchData`函数会顺序地等待`fetch`和`response.json()`两个异步操作完成,然后返回数据。
**优势**:
- 更加直观易读:与回调地狱相比,使用`async/await`可以使异步代码更像同步代码,提高了可读性和维护性。
- 错误处理简洁:`try/catch`块可以轻松处理错误,不需要嵌套。
- 避免回调地狱:异步操作可以自然地堆叠在一起,避免了回调函数的嵌套。
阅读全文