社区首页 >问答首页 >即使等待Promise.all()

即使等待Promise.all()
EN

Stack Overflow用户
提问于 2021-10-07 16:07:14
回答 1查看 618关注 0票数 1

在等待Promise.all()之后,我很难理解为什么我还有悬而未决的承诺。

在下面的示例中,我通过使用.map()对数组的每个元素调用异步函数来创建一个承诺数组。

现在,为什么承诺仍然是悬而未决的呢?我现在的理解是:

  • 一旦来自then()的承诺得到解决,storeData()就会触发
  • 一旦返回storeData()newDataArray就会解析
  • 一旦解决了newDataArray中的所有承诺,或者一旦第一个承诺被拒绝,就会返回promisesArray
代码语言:javascript
代码运行次数:0
复制
storeData(OldDataArray).then(values => console.log(values))
// console shows:
// { id: 1, data: Promise { <pending> } },
// { id: 2, data: Promise { <pending> } }
代码语言:javascript
代码运行次数:0
复制
const storeData = async (OldDataArray) => {
  try {
      const promisesArray = OldDataArray.map((item) => {
      let newData = downloadMoreDetails(item.id, item.group); //async function, see below
      return {
        id: item.id,
        data: newData,
      };
    });
    const newDataArray = await Promise.all(promisesArray);  // <-- I'm awaiting all promises to complete before assigning to newDataArray
    return newDataArray;
  } catch (error) {
    console.log(error)
  }
};
代码语言:javascript
代码运行次数:0
复制
const downloadMoreDetails = async (id, group) => {
  const response = await fetch(
    `example.com/id/group.xml`
  );
  if (!response.ok) {
    throw new Error(`HTTP error ${response.status}`);
  }

  const str = await response.text();
  const json = convert.xml2json(str, {
    compact: true,
    spaces: 2,
  });
  return json;
};
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-07 16:28:27

newData是一个承诺,但你没有等待承诺。相反,您正在等待一个对象数组( {id: item.id, data: newData } ),该数组中包含了它的承诺。Promise.all()不会在这些对象内部寻找承诺,然后等待承诺。它只看到一个简单的对象数组,这意味着它没有什么可做的。您可以通过这样做来解决这个问题:

代码语言:javascript
代码运行次数:0
复制
const storeData = async (OldDataArray) => {
  try {
    const promisesArray = OldDataArray.map(async (item) => {
        let newData = await downloadMoreDetails(item.id, item.group); //async function, see below
        return {
          id: item.id,
          data: newData,
        };
    });
    return Promise.all(promisesArray);
  } catch (error) {
    // log and rethrow error so the caller gets the rejection
    console.log(error);
    throw error;
  }
};

这将.map()回调更改为async。做两件有益的事。首先,这意味着来自.map()的结果数组将是一个承诺数组,因为async回调总是返回一个承诺。其次,它允许在回调中使用await,这样就可以用实际的数据填充返回的对象,而不是承诺。

然后,来自return回调内部的async将导致该值成为async函数返回的承诺的解析值。

注意,您也可以在不添加像这样的async/await的情况下完成它:

代码语言:javascript
代码运行次数:0
复制
const storeData = (OldDataArray) => {
    const promisesArray = OldDataArray.map((item) => {
       return downloadMoreDetails(item.id, item.group).then(newData => {
          return {
            id: item.id,
            data: newData,
          };
       });
    });
    return Promise.all(promisesArray).catch(error => {
      // log and rethrow error so the caller gets the rejection
      console.log(error);
      throw error;
    });
};

在这个版本中,您直接从.map()回调返回一个承诺,并确保该承诺解析为您的数据对象。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69489072

复制
相关文章
Python 代码风格指南谷歌版
非常感谢我们的忠实读者 shendeguize,在后台留言告诉我,已经翻译了《谷歌Python代码风格指南》 ,大家这样相互帮助,感觉真是太好。
double
2020/05/08
1.2K0
Python 代码风格指南谷歌版
Python 代码风格指南谷歌版
https://github.com/shendeguize/GooglePythonStyleGuideCN
龙哥
2020/05/05
1.3K0
分享Google C++风格指南
  Qt君为大家收集的Google C++风格指南PDF版本(可能并不是最新版本) 。
Qt君
2020/05/08
4940
分享Google C++风格指南
Google C++ 编程风格指南:注释
注释虽然写起来很痛苦, 但对保证代码可读性至关重要. 下面的规则描述了如何注释以及在哪儿注释. 当然也要记住: 注释固然很重要, 但最好的代码本身应该是自文档化. 有意义的类型名和变量名, 要远胜过要用注释解释的含糊不清的名字.
CPP开发前沿
2022/03/03
8540
谷歌Python代码风格指南,翻译版来了!
非常感谢我们的忠实读者 shendeguize,在后台留言告诉我,已经翻译了《谷歌Python代码风格指南》 ,大家这样相互帮助,感觉真是太好了。
程序员小猿
2021/01/19
1.5K0
谷歌Python代码风格指南,翻译版来了!
Google C++ 风格指南 - 中文版 [值得收藏]
http://yangyubo.com/google-cpp-styleguide/ 很实用的手册,感觉象是effective c++,但其中明确指出了一些在开发过程中应该尽力避免的特性与用法,完全基于经验判定,更加简练! 每一章后面还有译者的笔记,进行了总结! 1.代码小于10行时使用inline 2.private拷贝构造函数,尽量不重载运算符 3.少用继承,看是否能用组合代替
王亚昌
2018/08/03
3140
Google C++ 编程风格指南(三):类
类是 C++ 中代码的基本单元. 显然, 它们被广泛使用. 本节列举了在写一个类时的主要注意事项.
CPP开发前沿
2022/03/03
8320
Google C++ 编程风格指南:头文件
所有头文件要能够自给自足。换言之,用户和重构工具不需要为特别场合而包含额外的头文件。详言之,一个头文件要有 1.2. #define 保护,统统包含它所需要的其它头文件,也不要求定义任何特别 symbols.
CPP开发前沿
2022/03/03
7980
Google C++ 编程风格指南(八):格式
代码风格和格式确实比较随意, 但一个项目中所有人遵循同一风格是非常容易的. 个体未必同意下述每一处格式规则, 但整个项目服从统一的编程风格是很重要的, 只有这样才能让所有人能很轻松的阅读和理解代码.
CPP开发前沿
2022/03/03
1.7K0
JavaScript 风格指南 [每日前端夜话(0x1C)]
原文链接:https://github.com/ryanmcdermott/clean-code-javascript
疯狂的技术宅
2019/03/27
8710
JavaScript 风格指南 [每日前端夜话(0x1C)]
TensorFlow风格指南
片刻
2018/01/05
8330
Google C++ 编程风格指南(二):作用域
虽然类已经提供了(可嵌套的)命名轴线 (YuleFox 注: 将命名分割在不同类的作用域内), 名字空间在这基础上又封装了一层.
CPP开发前沿
2022/03/03
7910
Google C++ 编程风格指南(六):命名约定
最重要的一致性规则是命名管理. 命名风格快速获知名字代表是什么东东: 类型? 变量? 函数? 常量? 宏 … ? 甚至不需要去查找类型声明. 我们大脑中的模式匹配引擎可以非常可靠的处理这些命名规则.
CPP开发前沿
2022/03/03
1.8K0
Google C++ 编程风格指南(五):其他 C++ 特性
总之大多时候输入形参往往是 const T&. 若用 const T* 说明输入另有处理。所以若您要用 const T*, 则应有理有据,否则会害得读者误解。
CPP开发前沿
2022/03/03
1.2K0
Pointfree 编程风格指南
本文要回答一个很重要的问题:函数式编程有什么用? 目前,主流的编程语言都不是函数式的,已经能够满足需求。为何还要学函数式编程呢,只为了多理解一些新奇的概念? 一个网友说: "函数式编程有什么优势呢?
ruanyf
2018/04/12
8980
Pointfree 编程风格指南
[译] Google Go 风格指南
以下几条总体原则总结了如何编写可读的 Go 代码。以下为具有可读性的代码特征,按重要性排序:
pseudoyu
2023/04/11
2920
Airbnb React/JSX 风格指南
// bad <div accessKey="h" /> // good <div />
ConardLi
2019/05/23
1.4K0
flutter代码风格指南
•UpperCamelCase 每个单词的首字母都大写,包含第一个单词•lowerCamelCase 每个单词的首字母都大写,除了第一个单词, 第一个单词首字母小写,即使是缩略词•lowercase_with_underscores 只是用小写字母单词,即使是缩略词, 并且单词之间使用 _ 连接
用户1974410
2022/08/07
1.2K0
Google C++编程风格指南(四)之类的相关规范
类是C++中基本的代码单元,自然被广泛使用。本节列举了在写一个类时要做什么、不要做什么。
恋喵大鲤鱼
2018/08/03
8790
Google C++ 编程风格指南(四):来自 Google 的奇技
Google 用了很多自己实现的技巧 / 工具使 C++ 代码更加健壮, 我们使用 C++ 的方式可能和你在其它地方见到的有所不同.
CPP开发前沿
2022/03/03
7220

相似问题

谷歌C++风格指南的AStyle

14

谷歌C++风格指南包括订单

21

谷歌风格指南(前降部分)

20

示例代码与示例的C++谷歌风格指南?

24

C++操作符重载,了解谷歌风格指南

30
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档