3 回答
TA贡献1812条经验 获得超5个赞
使用 Date.parse() 从日期字符串中获取毫秒
let data = [{
name: 'John',
vouchers: [{
voucherId: 1,
issuedAt: '2020-12-15T16:26:36.3548091+01:00',
},
{
voucherId: 2,
issuedAt: '2020-12-15T16:26:36.3548091+01:00',
},
],
},
{
name: 'Lisa',
vouchers: [{
voucherId: 1,
issuedAt: '2020-12-13T16:26:36.3548091+01:00',
}, ],
},
];
data.sort(function(a, b) {
return (
Date.parse(a['vouchers'][0]['issuedAt']) -
Date.parse(b['vouchers'][0]['issuedAt'])
);
});
console.log(data)
TA贡献1862条经验 获得超6个赞
鉴于凭证数组都具有相同的issuedAt属性,您应该能够仅使用第一个条目来执行此操作:
const data = [{name: 'John', vouchers: [{voucherId: 1, issuedAt: '2020-12-15T16:26:36.3548091+01:00'}, {voucherId: 2, issuedAt: '2020-12-15T16:26:36.3548091+01:00'}]}, {name: 'Lisa', vouchers: [{voucherId: 1, issuedAt: '2020-12-13T16:26:36.3548091+01:00'}]}]
const sorter = ({vouchers: [{issuedAt: x}]}, {vouchers: [{issuedAt: y}]}) =>
x < y ? -1 : x > y ? 1 : 0
console .log ([...data] .sort (sorter))
我们使用[...data]廉价的浅克隆;我不想改变输入数据。但data .sort (sorter)如果你真的想改变你的数组,你可以直接调用。
TA贡献1868条经验 获得超4个赞
如果您希望首先列出最近时间的人员,请获取所有优惠券的最大发放日期并减去它们。
注意:我更改了时间,以便排序真正起作用。
const result = [{
name: 'John',
vouchers: [{
voucherId: 1,
issuedAt: '2020-12-15T16:26:36.3548091+01:00'
}, {
voucherId: 2,
issuedAt: '2020-12-15T17:26:36.3548091+01:00'
}, ]
}, {
name: 'John',
vouchers: [{
voucherId: 1,
issuedAt: '2020-12-13T18:26:36.3548091+01:00'
}]
}];
const sorted = result.sort(
({ vouchers: a = [] }, { vouchers: b = [] }) =>
Math.max(...a.map(({ issuedAt: d = 0 }) => new Date(d))) -
Math.max(...b.map(({ issuedAt: d = 0 }) => new Date(d)))
);
console.log(sorted);
.as-console-wrapper { top: 0; max-height: 100% !important; }
添加回答
举报