首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >按属性对JSON数组进行排序的通用方法

按属性对JSON数组进行排序的通用方法
EN

Stack Overflow用户
提问于 2012-06-19 19:02:19
回答 3查看 45.6K关注 0票数 19

我在http://www.devcurry.com/2010/05/sorting-json-array.html上了解了如何对JSON数组进行排序。

现在,我想以一种通用的方式对其进行排序;这样,我的排序函数就可以知道要按哪个属性进行排序。

例如,如果我的数组是

代码语言:javascript
复制
[
  {
    "name": "John",
    "age": "16"
  },
  {
    "name": "Charles",
    "age": "26"
  }
]

我想避免写不同的if大小写,以了解我是否应该按姓名或年龄排序。我只想传递一个参数'name‘或'age’,我的排序函数应该知道该怎么做。

谢谢。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-06-19 19:07:24

就像这样:

代码语言:javascript
复制
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") );
票数 80
EN

Stack Overflow用户

发布于 2014-12-18 18:24:05

您可以使用Alasql库按任何字段对数组进行排序:

代码语言:javascript
复制
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

票数 5
EN

Stack Overflow用户

发布于 2012-06-19 19:09:50

请参阅此示例http://jsfiddle.net/W8Byu/1/

我所做的是将排序列名存储在一个变量中,并在排序函数中使用。

代码语言:javascript
复制
 var sortColumnName = "Name";

 function SortByName(x,y) {
      return ((x[sortColumnName]  == y[sortColumnName]) ? 0 : ((x[sortColumnName]>    y[sortColumnName]) ? 1 : -1 ));
    }
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11099610

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档