js 对象数组sort排序
时间: 2025-05-16 16:48:05 浏览: 29
### JavaScript 对象数组使用 `sort` 方法进行排序
在 JavaScript 中,可以利用 `Array.prototype.sort()` 方法对对象数组进行自定义排序。通过向 `sort()` 提供一个比较函数作为参数,可以根据对象中的特定属性来决定顺序。
以下是基于对象数组的 `sort` 方法实现的一个具体示例:
#### 示例代码
假设有一个包含多个对象的数组,每个对象都有 `name` 和 `age` 属性,目标是对该数组按年龄升序排列。
```javascript
const people = [
{ name: 'Alice', age: 25 },
{ name: 'Bob', age: 30 },
{ name: 'Charlie', age: 20 }
];
people.sort((a, b) => a.age - b.age);
console.log(people);
// 输出结果:
// [
// { name: 'Charlie', age: 20 },
// { name: 'Alice', age: 25 },
// { name: 'Bob', age: 30 }
// ]
```
上述代码中,`sort` 的回调函数 `(a, b) => a.age - b.age` 定义了两个元素之间的比较逻辑[^1]。如果返回值小于零,则表示第一个元素应排在第二个之前;如果大于零则反之;等于零时表示两者位置不变。
对于更复杂的场景,比如需要先按某个字段降序再按另一个字段升序的情况,可以通过扩展比较逻辑完成:
```javascript
const items = [
{ category: 'fruit', price: 8 },
{ category: 'vegetable', price: 4 },
{ category: 'fruit', price: 6 },
{ category: 'vegetable', price: 7 }
];
items.sort((a, b) => {
if (a.category === b.category) {
return a.price - b.price; // 如果类别相同,按价格升序
} else {
return b.category.localeCompare(a.category); // 否则按类别降序
}
});
console.log(items);
// 输出结果可能如下(取决于 localeCompare 实现细节)
// [
// { category: 'vegetable', price: 4 },
// { category: 'vegetable', price: 7 },
// { category: 'fruit', price: 6 },
// { category: 'fruit', price: 8 }
// ]
```
在这个例子中,首先依据 `category` 字段执行降序操作,当两者的 `category` 值相等时,进一步根据 `price` 执行升序排序[^2]。
#### 注意事项
- 默认情况下,如果没有指定比较函数,`sort()` 将会把数组项视为字符串并按照 Unicode 编码点进行排序。
- 自定义比较函数允许开发者灵活控制排序行为,适用于各种复杂的数据结构和需求。
阅读全文
相关推荐


















