【问题标题】:How to get Async Function to work with Array.Filter passed-in element as its Argument如何让异步函数使用 Array.Filter 传入元素作为其参数
【发布时间】:2020-06-04 23:51:36
【问题描述】:

目标是检查 MongoDB 中的重复记录并返回一个新的文件对象 (filteredObj),其中不包含数据库中已存在的记录。每条记录都有一个描述码。

hasDuplicateDescription 方法返回一个 Promise,它解析为 true 或 false,如果数据库中没有现有的 record.description 则为 true,否则为 false。但是返回的filteredObj有原始的fileObj内容,没有做任何过滤。

  const filteredObj = fileObj.filter((record) => {
    return this.hasDuplicateDescription(record.description).then(
      (res) => {
        return res;
      }
    );
  });
  return filteredObj;

下面的解决方案是在其他帖子中让异步函数与 array.filter 一起使用的推荐解决方案,但在我的情况下它不起作用,因为 hasDuplicateDescription 是一个异步函数,需要 array.filter 方法传入的每个数组元素作为它的论据。

const results = await Promise.all(your_promises)
const filtered_results = results.filter(res => //do your filtering here)

感谢有关如何解决此问题的任何建议。

谢谢!

【问题讨论】:

  • 如果你需要收集所有过滤的结果,你必须等待所有的承诺完成。 async 只是将函数的返回值包装在一个 Promise 中,所以只需将它们全部收集起来并提供给 Promise.all

标签: javascript arrays


【解决方案1】:

您映射`您的数组中的每个元素以承诺解析过滤条件,将其与值过滤器结合起来,通过条件解析的结果映射到值:

const asyncFilter =  async (arr, asyncCheck) => (await Promise.all(arr.map(async (item) => [await asyncCheck(item), item]))).filter(([b]) => b).map(([, x]) => x)

asyncFilter(fileObj, (record) => this.hasDuplicateDescription(record.description))

【讨论】:

    猜你喜欢
    • 2021-07-16
    • 2023-02-01
    • 2020-12-27
    • 1970-01-01
    • 2012-05-24
    • 2020-06-28
    • 2020-10-13
    • 1970-01-01
    相关资源
    最近更新 更多