简体   繁体   English

如何将循环 promise 结果分配给 Expressjs 中的外部变量 Typescript?

[英]How to assign for loop promise result to the outside variable in Expressjs, Typescript?

export const getSObjectFields = async (request: Request, response: Response) => {
if (!request.body) { return response.status(401).json({ error: 'No SObject Selected' }); }
let selectedSObject = request.body;
let sObjectsDetails: any = [];
selectedSObject.forEach((element: string, _index: number) => {
    let promiseDescribeSObject = describeSObject(request, response, element);
    promiseDescribeSObject.then((res) => {
        sObjectsDetails.push(res);
    }).catch((err) => {
        console.error('Error: ', err);
    });
});
return response.status(200).json(sObjectsDetails);

} }

I do have a function that call an API with parameter describeSObject(request, response, 'objectName') .我确实有一个 function 调用带有参数describeSObject(request, response, 'objectName')的 API 。 I want to iterate the describeSObject function and save the result to the outside variable of for loop.我想迭代describeSObject function 并将结果保存到 for 循环的外部变量中。

You can use async/await syntax and use map and Promise.all to resolve all promises of the array together.您可以使用async/await语法并使用mapPromise.all一起解决数组的所有承诺。

export const getSObjectFields = async (request: Request, response: Response) => {
  if (!request.body) { return response.status(401).json({ error: 'No SObject Selected' }); }
  let selectedSObject = request.body;
  let sObjectsDetails = await Promise.all(selectedSObject.map(async (element: string) => await describeSObject(request, response, element)))
  return response.status(200).json(sObjectsDetails);
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM