根据其他数组的日期值获取数组值的总和

Get sum of array values based on date values of other array

所以我有这样的问题:

我有 2 个数组:
一个来自 mysql 查询,其中包含创建订单的日期及其总和

const ordersData = [
0: {id: 1, data: '2021-11-23T00:00:00.000Z', price: 394}
1: {id: 2, data: '2021-11-23T00:00:00.000Z', price: 315.3}
2: {id: 3, data: '2021-11-23T00:00:00.000Z', price: 16445}
...
6: {id: 7, data: '2021-11-23T00:00:00.000Z', price: 200}
7: {id: 8, data: '2021-12-22T00:00:00.000Z', price: 618}

]


第二个是数组,我有每月总和、月份、月份的第一天和最后一天

const pastMonthsData = [
   0: {
    month: "december",
    firstDay: Wed Dec 01 2021,
    lastDay: Fri Dec 31 2021,
    totalMonthSum: x
 },
   1: {
    month: "november",
    firstDay: Mon Nov 01 2021,
    lastDay: Tue Nov 30 2021,
    totalMonthSum: x
 }
]

我需要检查订单数组中的日期是否在 pastMonthsData 的日期之间并将价格添加到 totalMonthSum。
到目前为止,我像这样创建了 func,但它只适用于 12 月,11 月没有结果。

pastMonthsData.forEach((el, i) => {
        el.totalMonthSum = ordersData.reduce((total, item) => {
          let itemDate = new Date(item.data);
          if(el.firstDay.getTime() < itemDate.getTime() && itemDate.getTime() < el.lastDay.getTime()) {
            return total + item.price
          } else {
            return 0
          }
        })
      });

两个修复:

  1. 将累计总数初始化为零
  2. return 累计总数,而不是零,当日期不在范围内时

例如:

pastMonthsData.forEach((el, i) => {
  el.totalMonthSum = ordersData.reduce((total, item) => {
    let itemDate = new Date(item.data);
    if (el.firstDay.getTime() < itemDate.getTime() && itemDate.getTime() < el.lastDay.getTime()) {
      return total + item.price;
    } else {
      return total;
    }
  }, 0)
});