我正在尝试通过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
数组。有人可以帮我吗?迭代似乎是正确的,因为调试给了我所有日期,同样来自比较日期的真/假语句也是正确的。
提前致谢
答案 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;
}