Array.filter中如何正确使用Async
1. 如何仅保留满足异步条件的元素
在第一篇文章中,我们介绍了 async / await 如何帮助处理异步事件,但在异步处理集合时却无济于事。在本文中,我们将研究该filter函数,它可能是支持异步函数的最直观的方法。
2. Array.filter
该filter函数仅保留通过条件的元素。它得到一个断言( predicate )函数,并且此函数返回 true / false 值。结果集合仅包含断言( predicate )返回 true 的元素。
const arr = [1, 2, 3, 4, 5]; const syncRes = arr.filter((i) => { return i % 2 === 0; }); console.log(syncRes); // 2,4
3. filter 结合 map 使用
这次的异步版本要复杂一些,它分为两个阶段。第一个通过断言函数异步地映射数组,从而生成true / false 值。然后第二步是利用第一步的结果同步 filter
const arr = [1, 2, 3, 4, 5]; const asyncFilter = async (arr, predicate) => { const results = await Promise.all(arr.map(predicate)); return arr.filter((_v, index) => results[index]); } const asyncRes = await asyncFilter(arr, async (i) => { await sleep(10); return i % 2 === 0; }); console.log(asyncRes); // 2,4
或单行实现
const asyncFilter = async (arr, predicate) => Promise.all(arr.map(predicate))
.then((results) => arr.filter((_v, index) => results[index]));
并发
上面的实现运行所有断言函数。通常,这很好,与所有其他功能一样,它可能会使某些资源变得过分紧张。幸运的是,由于上述实现依赖于此map,可以使用相同的并发控件。
4. filter 结合 reduce 使用
除了使用异步map与同步之外filter,异步reduce 也可以完成这项工作。由于它只是一个功能,即使没有提供相同级别的控制,结构也更加容易。
,从一个空数组([])开始。然后通过断言函数运行下一个元素,如果通过则将其追加到数组。如果没有,请跳过它。
// concurrently const asyncFilter = async (arr, predicate) => arr.reduce(async (memo, e) => await predicate(e) ? [...await memo, e] : memo , []);
请注意,await predicate(e) 在 await memo 之前,这意味着这些将并行调用。
顺序处理
要在调用下一个谓词函数之前等待其结束,请更改await 的顺序
// sequentially const asyncFilter = async (arr, predicate) => arr.reduce(async (memo, e) => [...await memo, ...await predicate(e) ? [e] : []] , []);
此实现等待上一个元素,然后根据断言(...[e]或...[])的结果有条件地附加一个元素。
5. 结论
虽然异步filter是可能的,但它最初的工作方式看起来很奇怪。尽管并发控制仍然可用,但与其他异步功能相比,它们需要更多的计划去控制它。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程