(上)async/await高级用法,你会多少种呢?
公众号:程序员白特,欢迎一起交流学习~
前言
众所周知,在 ECMA17
中加入了两个关键字 async
、await
,简单来说它们是基于 Promise
之上的语法糖,可以让异步操作更加简洁明了。在掌握async
、await
的基础用法后,下面将介绍一些高级用法,以便充分利用async/await
实现更复杂的异步流程控制。
实现
1、使用async/await 优化递归
递归函数是编程中的一种常用技术,async/await
可以很容易地使递归函数进行异步操作。
// 异步递归函数
async function asyncRecursiveSearch(nodes) {
for (const node of nodes) {
await asyncProcess(node);
if (node.children) {
await asyncRecursiveSearch(node.children);
}
}
}
// 示例
async function asyncProcess(node) {
// 对节点进行异步处理逻辑
}
2、async/await与高阶函数结合使用
当需要对数组中的元素执行异步操作时,可结合async/await
与数组的高阶函数(如map
、filter
等)。
// 异步过滤函数
async function asyncFilter(array, predicate) {
const results = await Promise.all(array.map(predicate));
return array.filter((_value, index) => results[index]);
}
// 示例
async function isOddNumber(n) {
await delay(100); // 模拟异步操作
return n % 2 !== 0;
}
async function filterOddNumbers(numbers) {
return asyncFilter(numbers, isOddNumber);
}
filterOddNumbers([1, 2, 3, 4, 5]).then(console.log); // 输出: [1, 3, 5]
3、使用async/await 控制并发数
在处理诸如文件上传等场景时,可能需要限制同时进行的异步操作数量以避免系统资源耗尽。
async function asyncPool(poolLimit, array, iteratorFn) {
const result = [];
const executing = [];
for (const item of array) {
const p = Promise.resolve().then(() => iteratorFn(item, array));
result.push(p);
if (poolLimit <= array.length) {
const e = p.then(() => executing.splice(executing.indexOf(e), 1));
executing.push(e);
if (executing.length >= poolLimit) {
await Promise.race(executing);
}
}
}
return Promise.all(result);
}
// 示例
async function uploadFile(file) {
// 文件上传逻辑
}
async function limitedFileUpload(files) {
return asyncPool(3, files, uploadFile);
}
4、在async函数中使用await链式调用
使用await
可以直观地按顺序执行链式调用中的异步操作。
class ApiClient {
constructor() {
this.value = null;
}
async firstMethod() {
this.value = await fetch('/first-url').then(r => r.json());
return this;
}
async secondMethod() {
this.value = await fetch('/second-url').then(r => r.json());
return this;
}
}
// 使用方式
const client = new ApiClient();
const result = await client.firstMethod().then(c => c.secondMethod());
#前端##我的实习求职记录##23届找工作求助阵地##机械人晒出你的简历#