通过属性值排序JavaScript对象

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

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

有没有一种方法来根据值对属性进行排序? 所以我最终结束了

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

我对此有一个真正的脑死亡时刻。


将它们移到数组中,对该数组进行排序,然后将其用于您的目的。 这是一个解决方案:

var maxSpeed = {
    car: 300, 
    bike: 60, 
    motorbike: 200, 
    airplane: 1000,
    helicopter: 400, 
    rocket: 8 * 60 * 60
};
var 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对象中元素的顺序做出假设。


我们不想复制整个数据结构,或者在需要关联数组的地方使用数组。

这是另一种与bonna做同样的事情的方法:

var list = {"you": 100, "me": 75, "foo": 116, "bar": 15};
keysSorted = Object.keys(list).sort(function(a,b){return list[a]-list[b]})
alert(keysSorted);     // bar,me,you,foo

您的对象可以具有任何数量的属性,并且您可以选择根据所需的任何对象属性(数字或字符串)进行排序,如果将对象放入数组中。 考虑这个数组:

var arrayOfObjects = [   
    {
        name: 'Diana',
        born: 1373925600000, // Mon, Jul 15 2013
        num: 4,
        sex: 'female'
    },
    {

        name: 'Beyonce',
        born: 1366832953000, // Wed, Apr 24 2013
        num: 2,
        sex: 'female'
    },
    {            
        name: 'Albert',
        born: 1370288700000, // Mon, Jun 3 2013
        num: 3,
        sex: 'male'
    },    
    {
        name: 'Doris',
        born: 1354412087000, // Sat, Dec 1 2012
        num: 1,
        sex: 'female'
    }
];

按出生日期排序,年龄最大

// use slice() to copy the array and not just make a reference
var byDate = arrayOfObjects.slice(0);
byDate.sort(function(a,b) {
    return a.born - b.born;
});
console.log('by date:');
console.log(byDate);

按名称分类

var byName = arrayOfObjects.slice(0);
byName.sort(function(a,b) {
    var x = a.name.toLowerCase();
    var y = b.name.toLowerCase();
    return x < y ? -1 : x > y ? 1 : 0;
});

console.log('by name:');
console.log(byName);

http://jsfiddle.net/xsM5s/16/

链接地址: http://www.djcxy.com/p/31887.html

上一篇: Sorting JavaScript Object by property value

下一篇: CMake define new target by string processing existing $<TARGET