0

我有一个文件,其中从 api 调用多个导出函数,这些方法中的每一个都会在函数内部进行一些 get/post。所以我的问题是 Promise.all 对我来说看起来是多余的,是否有更好的方法来使用一个私有方法处理程序来实现这一点,该处理程序可以从每个导出函数和返回响应中实现或调用。

main.ts

export function getUser(req: Request, res: Response) {

  const p1 = Promise.resolve("data1");
  const p2 = Promise.resolve("data2");

    Promise.all([p1,p2])
        .then(function(results) {
            res.json(results);

        })
        .catch(function(e) {
            console.log(e)
        });

}

export function getRanks(req: Request, res: Response) {

   const p1 = Promise.resolve("data3");
   const p2 = Promise.resolve("data4");

    Promise.all([p1,p2])
        .then(function(results) {
            res.json(results);

        })
        .catch(function(e) {
            console.log(e)
        });

}
4

2 回答 2

1

你可以完全按照你写的去做——创建进行一般处理的函数。

export function getUser(req: Request, res: Response) {
  const p1 = Promise.resolve("data1");
  const p2 = Promise.resolve("data2");
  sendResponse(req, res, [p1,p2]);
}

export function getRanks(req: Request, res: Response) {
   const p1 = Promise.resolve("data3");
   const p2 = Promise.resolve("data4");
   sendResponse(req, res, [p1,p2]);
}

function sendResponse(req, res, promises) {
    Promise.all(promises)
        .then(function(results) {
            res.json(results);

        })
        .catch(function(e) {
            console.log(e)
        });
}

PS:您应该res在 .catch (res.end()res.status(500); res.json({error: e})) 中进行一些处理,否则请求将挂起 30-90 秒(根据您的设置)

于 2018-06-27T15:31:59.127 回答
0

万一p1等promise真的被创建了Promise.resolve,可以省略;Promise.all接受常规值。

可以用async..await更简洁的方式来写:

export async function getUser(req: Request, res: Response) {
  ...
  try {
    const results = await Promise.all([p1, p2]);
    res.json(results);
  } catch (e) {
    console.log(e)
  }
}

此时函数不需要进一步干燥。

于 2018-06-27T16:53:11.977 回答