我在http://www.devcurry.com/2010/05/sorting-json-array.html上了解了如何对JSON数组进行排序。
现在,我想以一种通用的方式对其进行排序;这样,我的排序函数就可以知道要按哪个属性进行排序。
例如,如果我的数组是
[
{
"name": "John",
"age": "16"
},
{
"name": "Charles",
"age": "26"
}
]
我想避免写不同的if大小写,以了解我是否应该按姓名或年龄排序。我只想传递一个参数'name‘或'age’,我的排序函数应该知道该怎么做。
谢谢。
发布于 2012-06-19 19:07:24
就像这样:
function predicateBy(prop){
return function(a,b){
if (a[prop] > b[prop]){
return 1;
} else if(a[prop] < b[prop]){
return -1;
}
return 0;
}
}
//Usage
yourArray.sort( predicateBy("age") );
yourArray.sort( predicateBy("name") );
发布于 2014-12-18 18:24:05
您可以使用Alasql库按任何字段对数组进行排序:
var data = [{"name":"John", "age":"16"}, {"name":"Charles", "age":"26"}];
var res1 = alasql('SELECT * FROM ? ORDER BY name',[data]);
var res2 = alasql('SELECT * FROM ? ORDER BY age',[data]);
var res3 = alasql('SELECT * FROM ? ORDER BY age, name',[data]);
var res4 = alasql('SELECT * FROM ? ORDER BY age DESC, name ASC',[data]);
尝试这个示例in jsFiddle。
发布于 2012-06-19 19:09:50
请参阅此示例http://jsfiddle.net/W8Byu/1/
我所做的是将排序列名存储在一个变量中,并在排序函数中使用。
var sortColumnName = "Name";
function SortByName(x,y) {
return ((x[sortColumnName] == y[sortColumnName]) ? 0 : ((x[sortColumnName]> y[sortColumnName]) ? 1 : -1 ));
}
https://stackoverflow.com/questions/11099610
复制相似问题