Array.filter中如何正确使用Async


Posted in Javascript onNovember 04, 2020

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

Array.filter中如何正确使用Async

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]));

Array.filter中如何正确使用Async

并发

上面的实现同时运行所有断言函数。通常,这很好,但是与所有其他功能一样,它可能会使某些资源变得过分紧张。幸运的是,由于上述实现依赖于此map,因此可以使用相同的并发控件。

4. filter 结合 reduce 使用

除了使用异步map与同步之外filter,异步reduce 也可以完成这项工作。由于它只是一个功能,因此即使没有提供相同级别的控制,结构也更加容易。

首先,从一个空数组([])开始。然后通过断言函数运行下一个元素,如果通过则将其追加到数组。如果没有,请跳过它。

Array.filter中如何正确使用Async

// concurrently
const asyncFilter = async (arr, predicate) => 
	arr.reduce(async (memo, e) =>
		await predicate(e) ? [...await memo, e] : memo
	, []);

Array.filter中如何正确使用Async

请注意,await predicate(e) 在 await memo 之前,这意味着这些将并行调用。

顺序处理

要在调用下一个谓词函数之前等待其结束,请更改await 的顺序:

// sequentially
const asyncFilter = async (arr, predicate) => 
	arr.reduce(async (memo, e) => 
		[...await memo, ...await predicate(e) ? [e] : []]
	, []);

此实现等待上一个元素,然后根据断言(...[e]或...[])的结果有条件地附加一个元素。

Array.filter中如何正确使用Async

5. 结论

虽然异步filter是可能的,但它最初的工作方式看起来很奇怪。尽管并发控制仍然可用,但与其他异步功能相比,它们需要更多的计划去控制它。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
控制打印时页眉角的代码
Feb 08 Javascript
jscript之Read an Excel Spreadsheet
Jun 13 Javascript
JavaScript 闭包深入理解(closure)
May 27 Javascript
浅谈javascript:两种注释,声明变量,定义函数
Sep 29 Javascript
BootStrop前端框架入门教程详解
Dec 25 Javascript
javascript深拷贝和浅拷贝详解
Feb 14 Javascript
关于javascript获取内联样式与嵌入式样式的实例
Jun 01 Javascript
Angular(5.2->6.1)升级小结
Dec 27 Javascript
vue使用高德地图根据坐标定位点的实现代码
Aug 22 Javascript
解决微信小程序中的滚动穿透问题
Sep 16 Javascript
vue-cli2与vue-cli3在一台电脑共存的实现方法
Sep 25 Javascript
vue实现图片上传预览功能
Dec 23 Javascript
JavaScript setTimeout()基本用法有哪些
Nov 04 #Javascript
vant-ui组件调用Dialog弹窗异步关闭操作
Nov 04 #Javascript
通过实例了解Render Props回调地狱解决方案
Nov 04 #Javascript
vant中的toast层级改变操作
Nov 04 #Javascript
vant中的toast轻提示实现代码
Nov 04 #Javascript
JavaScript快速调试的两个技巧
Nov 04 #Javascript
如何实现小程序与小程序之间的跳转
Nov 04 #Javascript
You might like
dedecms防止FCK乱格式化你的代码的修改方法
2007/03/17 PHP
PHP hex2bin()函数用法讲解
2019/02/25 PHP
Jquery ajax不能解析json对象,报Invalid JSON错误的原因和解决方法
2010/03/27 Javascript
如何在JavaScript中实现私有属性的写类方式(一)
2013/12/04 Javascript
根据当前时间在jsp页面上显示上午或下午
2014/08/18 Javascript
bootstrap table 服务器端分页例子分享
2015/02/10 Javascript
jquery实现动画菜单的左右滚动、渐变及图形背景滚动等效果
2015/08/25 Javascript
jquery实现移动端点击图片查看大图特效
2020/09/11 Javascript
超链接怎么正确调用javascript函数
2016/05/23 Javascript
Node.js开启Https的实践详解
2016/10/25 Javascript
Angular实现搜索框及价格上下限功能
2018/01/19 Javascript
详解Vue.js v-for不支持IE9的解决方法
2018/12/29 Javascript
vue 组件简介
2020/07/31 Javascript
[49:56]VG vs Optic 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
Python 基础教程之包和类的用法
2017/02/23 Python
Python Scapy随心所欲研究TCP协议栈
2018/11/20 Python
python向字符串中添加元素的实例方法
2019/06/28 Python
libreoffice python 操作word及excel文档的方法
2019/07/04 Python
Python 最强编辑器详细使用指南(PyCharm )
2019/09/16 Python
利用python实现PSO算法优化二元函数
2019/11/13 Python
解决python中的幂函数、指数函数问题
2019/11/25 Python
python利用xlsxwriter模块 操作 Excel
2020/10/14 Python
详解Python 中的 defaultdict 数据类型
2021/02/22 Python
CSS3 Media Queries详细介绍和使用实例
2014/05/08 HTML / CSS
欧舒丹澳洲版:L’OCCITANE
2017/07/17 全球购物
2014年端午节活动方案
2014/03/11 职场文书
教师师德承诺书
2014/03/26 职场文书
节能减排倡议书
2014/04/15 职场文书
人力资源本科毕业生求职信
2014/06/04 职场文书
孝敬父母的活动方案
2014/08/28 职场文书
创优争先心得体会
2014/09/11 职场文书
项目经理岗位职责范本
2015/04/01 职场文书
检举信的写法
2019/04/10 职场文书
申论不会写怎么办?教您掌握这6点思维和原则
2019/07/17 职场文书
2019预备党员转正申请书模板2篇!
2019/08/07 职场文书
导游词之永泰公主墓
2019/12/04 职场文书