假设我有一个记录数组:[{a:0,b:0},{a:2,b:1},{a:1,b:2}]
我希望按a
每个记录中字段的降序排序,并将排序后的记录作为一个新数组警告(即新数组将是[{a:2,b:1},{a:1,b:2},{a:0,b:0}]
) - 我将如何处理?我尝试了几种方法,但我的头撞到了墙上。
谢谢
假设我有一个记录数组:[{a:0,b:0},{a:2,b:1},{a:1,b:2}]
我希望按a
每个记录中字段的降序排序,并将排序后的记录作为一个新数组警告(即新数组将是[{a:2,b:1},{a:1,b:2},{a:0,b:0}]
) - 我将如何处理?我尝试了几种方法,但我的头撞到了墙上。
谢谢
一个简单的方法
var sorted = [{a:0,b:0},{a:2,b:1},{a:1,b:2}].sort( function( a, b )
{
if ( a.a == b.a ) return 0;
return ( a.a > b.a ) ? 1 : -1;
}).reverse();
以及更灵活的方法
// Note: console.log() require Firebug
var records = [{a:0,b:0},{a:2,b:1},{a:1,b:2}];
console.log( records );
// Sorty by 'a' ascending
sortByProperty( records, 'a' );
console.log( records );
// Sort by 'b' descending
sortByProperty( records, 'b', true );
console.log( records );
function sortByProperty( arr, property, descending )
{
arr.sort( function( a, b )
{
return Boolean( descending )
? b[property] - a[property]
: a[property] - b[property]
} );
}
也适用于字符串的版本
// Note: console.log() require Firebug
var records = [
{a:0,b:0}
, {a:2,b:1}
, {a:'banana',b:'apple'}
, {a:1,b:2}
, {a:'apple',b:'banana'}
];
console.log( records );
// Sorty by 'a' ascending
sortByProperty( records, 'a' );
console.log( records );
// Sort by 'b' descending
sortByProperty( records, 'b', true );
console.log( records );
function sortByProperty( arr, property, descending )
{
arr.sort( function( a, b )
{
var c = a[property].toString()
, d = b[property].toString()
if ( c == d ) return 0;
return Boolean( descending )
? d > c ? 1 : -1
: d < c ? 1 : -1
} );
}
休斯我的同事今天刚刚向我展示了以下内容。
请注意使用 -cmp() 和 cmp() 进行降序和升序。
var cmp = function(x, y){ return x > y? 1 : x < y ? -1 : 0; },
arr = [{a:0,b:0},{a:2,b:1},{a:1,b:2},{a:2, b:2}];
// a ascending
arr.sort(function(x, y){
return cmp(x.a, y.a) < cmp(y.a, x.a) ? -1:1;
});
// a descending
arr.sort(function(x, y){
return -cmp(x.a, y.a) < -cmp(y.a, x.a) ? -1:1;
});
// a ascending, b descending
arr.sort(function(x, y){
return [cmp(x.a, y.a), -cmp(x.b, y.b)] < [cmp(y.a, x.a), -cmp(y.b,x.b)] ? -1:1;
});
使用闭包比直接引用函数要慢。
// assume var records = [{a:0,b:0},{a:2,b:1},{a:1,b:2}];
records.sort(myCustomSort);
function myCustomSort(a, b) {
return (b.a - a.a);
}
如果您确实需要新数组的第二个变量,只需在调用自定义排序方法之前复制初始数组即可。
排序代表怎么样?
[{a:0,b:0},{a:2,b:1},{a:1,b:2}].sort(function(a,b){
// see http://www.javascriptkit.com/javatutors/arraysort.shtml
// for an explanation of this next line
return b.a-a.a;
});
(保存后,我注意到另外两个几乎相同的答案,但由于细微的差异,我将把我的答案留在这里。)
// your items array
var items = [{a:0,b:0},{a:2,b:1},{a:1,b:2}];
// function we can use as a sort callback
var compareItemsBy_a_Descending = function(x,y) {
return y.a - x.a;
};
// function to alert the items array
var displayItems = function(items) {
var out = [];
for (var i=0;i<items.length;i++) {
out.push('{a:' + items[i].a + ',b:' + items[i].b + '}');
}
alert('[' +out.join(',') + ']');
};
// run it
displayItems(items);
结果:[{a:0,b:0},{a:2,b:1},{a:1,b:2}]
// sort it
items.sort(compareItemsBy_a_Descending);
// run it again
displayItems(items);
结果:[{a:2,b:1},{a:1,b:2},{a:0,b:0}]