javascript - 按值对对象属性进行排序

标签 javascript sorting properties object

如果我有一个 JavaScript 对象,例如:

var list = {
  "you": 100, 
  "me": 75, 
  "foo": 116, 
  "bar": 15
};

有没有办法根据值对属性进行排序?所以我最终得到

list = {
  "bar": 15, 
  "me": 75, 
  "you": 100, 
  "foo": 116
};

最佳答案

将它们移动到一个数组中,对该数组进行排序,然后将该数组用于您的目的。解决办法如下:

let maxSpeed = {
    car: 300, 
    bike: 60, 
    motorbike: 200, 
    airplane: 1000,
    helicopter: 400, 
    rocket: 8 * 60 * 60
};
let sortable = [];
for (var vehicle in maxSpeed) {
    sortable.push([vehicle, maxSpeed[vehicle]]);
}

sortable.sort(function(a, b) {
    return a[1] - b[1];
});

// [["bike", 60], ["motorbike", 200], ["car", 300],
// ["helicopter", 400], ["airplane", 1000], ["rocket", 28800]]
<小时/>

一旦获得了数组,您就可以按照您喜欢的顺序从数组中重建对象,从而完全实现您想要做的事情。这适用于我所知道的所有浏览器,但它取决于实现的怪癖,并且可能随时中断。您永远不应该对 JavaScript 对象中元素的顺序做出假设。

let objSorted = {}
sortable.forEach(function(item){
    objSorted[item[0]]=item[1]
})
<小时/>

在 ES8 中,您可以使用 Object.entries()将对象转换为数组:

const maxSpeed = {
    car: 300, 
    bike: 60, 
    motorbike: 200, 
    airplane: 1000,
    helicopter: 400, 
    rocket: 8 * 60 * 60
};

const sortable = Object.entries(maxSpeed)
    .sort(([,a],[,b]) => a-b)
    .reduce((r, [k, v]) => ({ ...r, [k]: v }), {});

console.log(sortable);

<小时/>

在 ES10 中,您可以使用 Object.fromEntries()将数组转换为对象。那么代码可以简化为:

const maxSpeed = {
    car: 300, 
    bike: 60, 
    motorbike: 200, 
    airplane: 1000,
    helicopter: 400, 
    rocket: 8 * 60 * 60
};

const sortable = Object.fromEntries(
    Object.entries(maxSpeed).sort(([,a],[,b]) => a-b)
);

console.log(sortable);

关于javascript - 按值对对象属性进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59395669/

相关文章:

python - 列的属性行为(getter 和 setter),而不是正常的属性行为

python - 滥用 'property' 保留字

javascript - 在django模板中单击按钮时播放音频

javascript - 如何直接追加Json对象?

javascript - 按字母顺序对 JSON(按特定元素)排序

Javascript:在特定数组结构上使用 array.sort()

ios - 只读公共(public),读写私有(private)属性(property)

javascript - Sails.js:如何使用模型关联填充数组

javascript - ReactJS 项目中 webpack 导入的行为是什么?

MySQL:查询过滤列后获取最大值