可以通过将缺少所需属性的对象移到数组的开头来解决这个问题。一种实现方式是使用Array.prototype.sort()方法自定义排序逻辑。
例如,假设我们有一个对象数组,每个对象都有一个名为"age"的属性。但有些对象可能没有"age"属性。
const people = [
{ name: "Alice", age: 31 },
{ name: "Bob", age: undefined },
{ name: "Charlie", age: 25 },
{ name: "Dave" },
{ name: "Emily", age: 27 }
];
现在,如果我们想按年龄对这些人进行排序,但想在年龄未定义或不存在的人之前保留它们,我们可以编写自定义排序函数如下所示:
function sortByAge(person1, person2) {
if (person1.age === undefined) {
return -1;
}
if (person2.age === undefined) {
return 1;
}
return person1.age - person2.age;
}
这个函数首先检查第一个人的年龄是否未定义。如果是,它就把第一个人移动到比第二个人前面。然后,它检查第二个人的年龄是否未定义。如果是,它将第二个人移动到比第一个人前面。最后,如果两个人都有定义的年龄,它将它们按年龄进行排序。
现在,我们可以对数组进行排序,传入这个自定义函数作为参数:
const sortedPeople = people.sort(sortByAge);
这将返回一个新的数组,其中人根据其年龄进行排序,并且那些无年龄信息的人优先于有年龄信息的人:
[
{ name: "Bob", age: undefined },
{ name: "Dave" },
{ name