解决错误500; "Cannot access 'object' before initialization"}

Resolving error 500; "Cannot access 'object' before initialization" }

正在寻求有关如何解决此错误的帮助。我正在尝试根据每个月内发生的交易总和来获取每月交易总和的数组。

下面是我的代码,

exports.monthlyTotalArray = async (req, res) => {
  const { userId } = req.body;
  const requestMonths = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];
  const today = new Date();
  var relevantYear = today.getYear();

  try {
    return await Transaction.findAll({
      where: {
        userId: userId,
      },
    }).then((transactions) => {
      if (transactions.length == 0) {
        res.status(401).json({
          message: { msgBody: "No transactions found", msgError: true },
        });
      } else {
        const MonthlyArray = requestMonths.forEach((requestMonth) => {
          transactions
            .filter((i) => {
              const date = new Date(i.date);
              return (
                date.getMonth() == requestMonth &&
                date.getYear() == relevantYear
              );
            })
            .reduce((prev, curr) => prev + parseFloat(curr.amount), 0);
          res.status(200).send({
            MonthlyArray,
          });
        });
      }
    });
  } catch (error) {
    res.status(500).send({
      message: error.message || "some error occurred",
    });
  }
};

当我尝试 运行 代码

时出现此错误
{
  "message": "Cannot access 'MonthlyArray' before initialization"
}

您似乎正在访问 foreach() lambda 表达式中的 MonthlyArray。但是 MonthlyArray 实际上是由 foreach() 的结果初始化的,因此您确实在初始化之前访问了 MonthlyArray。

这可能不是您想要的,但您发送响应的代码部分在 lambda 表达式中。

很难看清,因为代码的缩进让人很难理解 lambda 表达式的结束位置。

代码的适当缩进很可能会使其显而易见。

主要问题是您在 requestMonths.forEach 的回调函数内部调用 res.send({ MonthlyArray }),所以这就是您收到错误的原因。

const MonthlyArray = requestMonths.forEach((requestMonth) => {
  // you're calling it here
  res.status(200).send({
    MonthlyArray,
  });
});
// instead, it should be here
res.status(200).send({
  MonthlyArray,
});

此外,您可能不想使用 forEach,因为 forEach 没有 return 任何东西,所以 MonthlyArray 将是 undefined。相反,请使用 Array.map 来获得您需要的结果。

if (transactions.length == 0) {
  // ...
} else {
  const MonthlyArray = requestMonths.map((requestMonth) => {
    return transactions
      .filter((i) => {
        const date = new Date(i.date);
        return (
          date.getMonth() == requestMonth && date.getYear() == relevantYear
        );
      })
      .reduce((prev, curr) => prev + parseFloat(curr.amount), 0);
  });
  res.status(200).send({
    MonthlyArray,
  });
}