Generic way of sorting JSON array by attribute

后端 未结 3 1303
野的像风
野的像风 2020-12-07 21:32

I found out how to sort a JSON array at http://www.devcurry.com/2010/05/sorting-json-array.html

Now I want to sort it in a generic way; so that my sorting function k

相关标签:
3条回答
  • 2020-12-07 21:52

    Something like a:

    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") );
    
    0 讨论(0)
  • 2020-12-07 21:54

    See this example http://jsfiddle.net/W8Byu/1/

    What I have done is stored the sort column Name in a variable and used in Sort function.

     var sortColumnName = "Name";
    
     function SortByName(x,y) {
          return ((x[sortColumnName]  == y[sortColumnName]) ? 0 : ((x[sortColumnName]>    y[sortColumnName]) ? 1 : -1 ));
        }
    
    0 讨论(0)
  • 2020-12-07 22:01

    You can sort arrays by any field with Alasql library:

    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]);
    

    Try this example in jsFiddle.

    0 讨论(0)
提交回复
热议问题