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 相关文章推荐
用正则xmlHttp实现的偷(转)
Jan 22 Javascript
在html页面中包含共享页面的方法
Oct 24 Javascript
JavaScript 继承详解 第一篇
Aug 30 Javascript
细说浏览器特性检测(2)-通用事件检测
Nov 05 Javascript
javascript完美拖拽的实现方法
Sep 29 Javascript
xmlhttp缓存清除的2种解决方法
Dec 13 Javascript
JavaScript中的apply和call函数详解
Jul 20 Javascript
JavaScript学习笔记之基础语法
Jan 22 Javascript
AngularJS基础 ng-mouseover 指令简单示例
Aug 02 Javascript
jquery层次选择器的介绍
Jan 18 jQuery
vue动态合并单元格并添加小计合计功能示例
Nov 26 Vue.js
vue如何在data中引入图片的正确路径
Jun 05 Vue.js
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
咖啡语言
2021/03/03 咖啡文化
解析php防止form重复提交的方法
2013/07/01 PHP
php目录操作实例代码
2014/02/21 PHP
使用 PHPStorm 开发 Laravel
2015/03/24 PHP
PHP自带方法验证邮箱、URL、IP是否合法的函数
2016/12/08 PHP
使用PHPUnit进行单元测试并生成代码覆盖率报告的方法
2019/03/08 PHP
JavaScript判断两种格式的输入日期的正确性的代码
2007/03/25 Javascript
让FireFox支持innerText的实现代码
2009/12/01 Javascript
JavaScript 学习笔记(十四) 正则表达式
2010/01/22 Javascript
Javascript创建自定义对象 创建Object实例添加属性和方法
2012/06/04 Javascript
JS中获取数据库中的值的方法
2013/07/14 Javascript
javascript中错误使用var造成undefined
2016/03/31 Javascript
jquery mobile界面数据刷新的实现方法
2016/05/28 Javascript
Nodejs回调加超时限制两种实现方法
2017/06/09 NodeJs
js移动端事件基础及常用事件库详解
2017/08/15 Javascript
在原生不支持的旧环境中添加兼容的Object.keys实现方法
2017/09/11 Javascript
VSCode 配置React Native开发环境的方法
2017/12/27 Javascript
vue获取当前点击的元素并传值的实例
2018/03/09 Javascript
vue-cli初始化项目中使用less的方法
2018/08/09 Javascript
使用wxapp-img-loader自定义组件实现微信小程序图片预加载功能
2018/10/18 Javascript
Vue中对iframe实现keep alive无刷新的方法
2019/07/23 Javascript
layer弹窗在键盘按回车将反复刷新的实现方法
2019/09/25 Javascript
js判断密码强度的方法
2020/03/18 Javascript
python实现根据图标提取分类应用程序实例
2014/09/28 Python
python使用json序列化datetime类型实例解析
2018/02/11 Python
实例详解Matlab 与 Python 的区别
2019/04/26 Python
python判断自身是否正在运行的方法
2019/08/08 Python
分享8点超级有用的Python编程建议(推荐)
2019/10/13 Python
python模块和包的应用BASE_PATH使用解析
2019/12/14 Python
python实现斗地主分牌洗牌
2020/06/22 Python
阿迪达斯法国官方网站:adidas法国
2018/03/20 全球购物
师范生实习自我鉴定
2013/11/01 职场文书
爱国主义影片观后感
2015/06/18 职场文书
如何书写公司员工保密协议?
2019/06/27 职场文书
Java数组与堆栈相关知识总结
2021/06/29 Java/Android
Python echarts实现数据可视化实例详解
2022/03/03 Python