按属性对 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 数组进行排序的通用方法的主要内容,如果未能解决你的问题,请参考以下文章

按升序或降序对数字或字母进行通用排序

CSharpGL(36)通用的非托管数组排序方法

对二维矩阵进行排序的方法,我怎样才能使该方法通用?

根据两个或多个值对通用列表进行排序

Swift 2.0 按属性对对象数组进行排序

Java:通用的排序工具类,能够对自定义对象,针对不同的属性(字段),实现排序(正序倒序)