在 Array.filter 中正確使用 Async

来源:https://www.cnblogs.com/luckrain7/archive/2020/04/13/12690674.html
-Advertisement-
Play Games

本文譯自 "How to use async functions with Array.filter in Javascript Tamás Sallai " 。 0. 如何僅保留滿足非同步條件的元素 在 "第一篇文章中" ,我們介紹了 async / await 如何幫助處理非同步事件,但在非同步處理集 ...


本文譯自How to use async functions with Array.filter in Javascript - Tamás Sallai

0. 如何僅保留滿足非同步條件的元素

第一篇文章中,我們介紹了 async / await 如何幫助處理非同步事件,但在非同步處理集合時卻無濟於事。在本文中,我們將研究該filter函數,它可能是支持非同步函數的最直觀的方法。

1. 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

2. filter 結合 map 使用

這次的非同步版本要複雜一些,它分為兩個階段。第一個通過斷言函數非同步地映射數組,從而生成true / false 值。然後第二步是利用第一步的結果同步 filter

Async 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是可能的,但它最初的工作方式看起來很奇怪。儘管併發控制仍然可用,但與其他非同步功能相比,它們需要更多的計划去控制它。

推薦閱讀

您的關註是莫大的鼓勵


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、承接連載3,講解基本數據類型 1.Number (3)NaN非法數字(Not A Number) JS中對數值進行計算沒有結果的時候,返回NaN <script> var num = NaN; console.log(num); console.log(typeof NaN); </script ...
  • Github項目地址:https://github.com/bravedreamer/test/tree/master/Arithmetic 線上預覽:https://bravedreamer.github.io/test/Arithmetic/index.html 項目合作者:吳尚謙 311800 ...
  • 有 3 種定義函數的方式 函數聲明 函數表達式 Function 構造函數(很少使用) 函數聲明 關鍵字後需要指定函數名 函數表達式 關鍵字後不用指定函數名;函數末尾需要添加一個分號,就像聲明其他變數時一樣 Function 構造函數 構造函數可以接收任意數量的參數,但最後一個參數始終都被看成是函數 ...
  • 剛看了下《JavaScript入門與實戰》視頻前2章,簡單講解了下學習js需要註意的事項與準備;雖然學習本身是一件無聊且枯燥的事情,但是誰叫咱是靠鍵盤吃飯的,沒辦法,"如果可以靠臉吃飯,誰願意靠才華",當然這個扯遠了;前2節感興趣的是這個打字拒絕‘二指彈’,學會用我們的鍵盤,建議電腦安裝金山打字練習... ...
  • 微信小程式 wx.request 發起 HTTPS 網路請求。 示例代碼 不進行二次封裝確實不太好用 分享下我這邊 的封裝 api.js js const app = getApp() const request = (url, options) = { return new Promise((re ...
  • 版權聲明:本文轉載至CSDN博主「詩人與黑客」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。原文鏈接:https://blog.csdn.net/qq_41899174/article/details/82797089感謝博主,感謝分享,對於for迴圈咋們不能 ...
  • layui產生背景 layui相對於vue來說確實稍有遜色,但是官網提供的入門文檔以及完善的框架結構,使的很多人開始用layui來開發前端頁面,那麼什麼人會去使用layui呢? 針對後端開發人員,在對前端知之甚少的情況下需要自行開發前端頁面 前後端數據動態交互要求較低的前端開發工程師 測試開發工程師 ...
  • 學習分享變數聲明、變數類型,如何對它們進行賦值、改變、計算等一系列操作,掌握不同運算符的使用方法,靈活運用算術運算符、比較運算符、邏輯運算符對變數和數值進行操作。 2-1 什麼是變數 2-2 給變數取個名字(變數命名) 2-3 確定你的存在(變數聲明) 2-4 多樣化的我(變數賦值) 2-5 表達出 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...