按属性对 JSON 数组进行排序的通用方法
Posted
技术标签:
【中文标题】按属性对 JSON 数组进行排序的通用方法【英文标题】:Generic way of sorting JSON array by attribute 【发布时间】:2012-06-21 09:53:39 【问题描述】:我在http://www.devcurry.com/2010/05/sorting-json-array.html 发现了如何对 JSON 数组进行排序
现在我想以一种通用的方式对其进行排序;这样我的排序函数就知道要排序的属性。
例如,如果我的数组是
[
"name": "John",
"age": "16"
,
"name": "Charles",
"age": "26"
]
我想避免写不同的 if 案例来知道我是否应该按姓名或年龄排序。我只想传递一个参数“姓名”或“年龄”,我的排序函数应该知道该怎么做。
谢谢。
【问题讨论】:
那么你有没有尝试过?顺便说一句,您链接的文章以及您实际想要做的事情与 JSON 无关;您正在操作常规 javascript 数据结构,而 JSON 是此类结构的字符串序列化。 你是对的。我没有正确地提出问题。 【参考方案1】:有点像:
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") );
【讨论】:
@Engineer:这是在骂人吗?不错的一个虽然 + 1 这到底是如何工作的?什么被分配给 a 什么被分配给 b 以及如何分配? @WeDoTDD 查看Array.sort 文档【参考方案2】:您可以使用 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。
【讨论】:
这应该是公认的答案,这有助于提供除了排序之外的所有 sql 功能。非常感谢! :)【参考方案3】:看这个例子 http://jsfiddle.net/W8Byu/1/
我所做的是将排序列名称存储在一个变量中并在排序函数中使用。
var sortColumnName = "Name";
function SortByName(x,y)
return ((x[sortColumnName] == y[sortColumnName]) ? 0 : ((x[sortColumnName]> y[sortColumnName]) ? 1 : -1 ));
【讨论】:
以上是关于按属性对 JSON 数组进行排序的通用方法的主要内容,如果未能解决你的问题,请参考以下文章