按日期在2个日期之间过滤数组

时间:2018-01-12 13:29:08

标签: javascript angular typescript

我正在尝试通过TypeScript中用户的日期/日期输入来过滤LineChart的数据数组,以用于我的Angular App。 数据数组具有以下结构:

var multi = [
    {
      "name": "test1",
      "series": [
        {
            "date": new Date("2018-01-01T01:10:00Z"),
            "value": 44
        },...
      ]
    },
    {
      "name": "test2",
      "series": [
        {
            "date": new Date("2018-01-01T01:10:00Z"),
            "value": 38
          },...
      ]
    },
    {
      "name": "test3",
      "series": [
        {
            "date": new Date("2018-01-01T01:10:00Z"),
            "value": 33
          },...
      ]
    }
  ];

我现在想要按照内部日期在'fromDate'之后和'toDate'之前的条件过滤数组的项目。我尝试了以下方法:

obj.forEach(data => {
            console.log(data.name);
            data.series = data.series.filter((item: any) => {
                item.date.getTime() >= fromDate.getTime() &&
                item.date.getTime() <= toDate.getTime();
            });
        });

obj[]数组之后有一个空的obj[i].series数组。有人可以帮我吗?迭代似乎是正确的,因为调试给了我所有日期,同样来自比较日期的真/假语句也是正确的。

提前致谢

3 个答案:

答案 0 :(得分:13)

您需要return比较值,显式

data.series = data.series.filter((item: any) => {
    return item.date.getTime() >= fromDate.getTime() &&
           item.date.getTime() <= toDate.getTime();
});

或没有括号,隐含。

data.series = data.series.filter((item: any) =>
    item.date.getTime() >= fromDate.getTime() && item.date.getTime() <= toDate.getTime()
);

答案 1 :(得分:1)

let start = new Date(this.min);
let end   = new Date(this.max);

return items.filter(item => {
   let date = new Date(item.created_at);
   return date >= start && date <= end;
}

答案 2 :(得分:0)

当结束日期与开始日期相同时,我遇到了一个问题,我不得不将结束日期的时间设置为23.59

const start =  new Date().getTime()
const end=new Date()
end.setHours(23,59,59,999)
end.getTime()

return items.filter(item => {
   let date = new Date(item.created_at).getTime();
   return date >= start && date <= end;
}