我想用一个可以按日期排序的命令排序函数对两个数组进行排序。
videos = [
{publishDate: new Date("2016-07-20T07:45:00Z").toISOString()},
{publishDate: new Date("2016-07-27T07:45:00Z").toISOString()},
{publishDate: new Date("2016-07-23T07:45:00Z").toISOString()}
];
persons = [
{dob: new Date("2016-07-10T07:45:00Z").toISOString()},
{dob: new Date("2016-07-08T07:45:00Z").toISOString()},
{dob: new Date("2016-07-11T07:45:00Z").toISOString()}
];
我可以使用此函数byDate()进行排序
function byDate(v1, v2) {
return v1.p > v2.p ? 1 : -1;
}
videos.sort(byDate);
但是当我使用person []数组调用此函数时,这会出错,因为在person []数组中不存在v1.p。
因此,我需要一个可以对不同对象数组进行排序的排序函数。
答案 0 :(得分:5)
您需要指定要排序的键。该解决方案采用密钥并返回用于排序的函数。
function byDate(key) {
return function (a, b) {
return a[key].localeCompare(b[key]);
};
}
var videos = [{ publishDate: new Date("2016-07-20T07:45:00Z").toISOString() }, { publishDate: new Date("2016-07-27T07:45:00Z").toISOString() }, { publishDate: new Date("2016-07-23T07:45:00Z").toISOString() }],
persons = [{ dob: new Date("2016-07-10T07:45:00Z").toISOString() }, { dob: new Date("2016-07-08T07:45:00Z").toISOString() }, { dob: new Date("2016-07-11T07:45:00Z").toISOString() }];
console.log(videos.sort(byDate('publishDate')));
console.log(persons.sort(byDate('dob')));
.as-console-wrapper { max-height: 100% !important; top: 0; }
答案 1 :(得分:0)
只需尝试
videos = [
{publishDate: new Date("2016-07-20T07:45:00Z").toISOString()},
{publishDate: new Date("2016-07-27T07:45:00Z").toISOString()},
{publishDate: new Date("2016-07-23T07:45:00Z").toISOString()}
];
persons = [
{dob: new Date("2016-07-10T07:45:00Z").toISOString()},
{dob: new Date("2016-07-08T07:45:00Z").toISOString()},
{dob: new Date("2016-07-11T07:45:00Z").toISOString()}
];
function byDate(v1, v2) {
return Object.values(v1) > Object.values(v2) ? 1 : -1;
}
console.log(videos.sort(byDate));
console.log(persons.sort(byDate));