如何使用underscore.js对多个键进行排序?

时间:2016-10-04 09:14:32

标签: javascript sorting underscore.js

让我们说我有一张桌子" employeeTbl_1"

如果我运行以下查询

 select * from employeeTbl_1

输出

 1  Adam        23000
 2  Adam        22000
 3  Annabel     13500
 4  Abraham     13000
 5  Alan        12000
 6  Svatlana    1500
 7  Svatlana    1400
 8  Shane       12000

现在,如果我使用" employeeName"

对上表进行排序

输出如下,

select * from employeeTbl_1 order by employeeName

4   Abraham     13000
1   Adam        23000
2   Adam        22000
5   Alan        12000
3   Annabel     13500
8   Shane       12000
6   Svatlana    1500
7   Svatlana    1400

现在,如果我使用" employeeName"对表进行排序和"薪水"两者,输出如下,

select * from employeeTbl_1 order by employeeName, salary

4   Abraham     13000
2   Adam        22000
1   Adam        23000
5   Alan        12000
3   Annabel     13500
8   Shane       12000
7   Svatlana    1400
6   Svatlana    1500

您可以在上面看到(即第3个输出)表格根据列

进行排序

我需要在javaScript中使用underscore.js库实现

请按照以下代码

 var _ = require("underscore");

 var employeeList = [   {"id" : 1, "name" : "Adam", "salary" : 23000 },
                    {"id" : 2, "name" : "Adam", "salary" : 22000 },
                    {"id" : 3, "name" : "Annabel", "salary" : 13500 },
                    {"id" : 4, "name" : "Abraham", "salary" : 13000 },
                    {"id" : 5, "name" : "Alan", "salary" : 12000 },
                    {"id" : 6, "name" : "Svatlana", "salary" : 1500 },
                    {"id" : 7, "name" : "Svatlana", "salary" : 1400 },
                    {"id" : 8, "name" : "Shane", "salary" : 12000 },
                ];

 function sortEmployee(list){
    return _.sortBy(_.sortBy(list,"name"),"salary");
 }

 console.log(sortEmployee(employeeList));                   

如果我运行上面的代码,输出是,

 rahul@rahul:~/myPractise/FunctionalJavascriptPractise$ node practise22.js 
 [ { id: 7, name: 'Svatlana', salary: 1400 },
   { id: 6, name: 'Svatlana', salary: 1500 },
   { id: 5, name: 'Alan', salary: 12000 },
   { id: 8, name: 'Shane', salary: 12000 },
   { id: 4, name: 'Abraham', salary: 13000 },
   { id: 3, name: 'Annabel', salary: 13500 },
   { id: 2, name: 'Adam', salary: 22000 },
   { id: 1, name: 'Adam', salary: 23000 } ]
 rahul@rahul:~/myPractise/FunctionalJavascriptPractise$

从输出中你可以看到集合按一个条件排序,即" salary"。

如何在JavaScript中使用普通的javaScript或使用underscore.js在SQL中实现排序。

我尝试使用普通的javaScript和underScore.js

function sortEmployee(list){
   return list.sort(function(employee1,employee2){      
    return _.isEqual(employee1.name,employee2.name) ?
            (_.isEqual(employee1.name,employee2.name) && (employee1.salary < employee2.salary)) : _.isEqual(employee1.name,employee2.name);
    });
}

console.log(sortEmployee(employeeList));

输出

[ { id: 1, name: 'Adam', salary: 23000 },
  { id: 2, name: 'Adam', salary: 22000 },
  { id: 3, name: 'Annabel', salary: 13500 },
  { id: 4, name: 'Abraham', salary: 13000 },
  { id: 5, name: 'Alan', salary: 12000 },
  { id: 6, name: 'Svatlana', salary: 1500 },
  { id: 7, name: 'Svatlana', salary: 1400 },
  { id: 8, name: 'Shane', salary: 12000 } ]

我仍然没有获得所需的输出,我在sql排序中获得

1 个答案:

答案 0 :(得分:1)

下划线的sortBy也接受一个iteratee函数,如果你传递一个首先检查名称的函数,如果它们相等,那么你将获得所需的排序。

comparator(v1, v2){
   return ((v1.name  - v2.name) || (v1.value - v2.value))
}

如果名称相同,则第二个子句开始并比较值。

阅读完评论后,这是一个更新版本:

function nameSalaryComparator(v1, v2){
  return (v1.name === v2.name ?
          v1.salary - v2.salary :
          (v1.name > v2.name ? 1 : -1));
}

您可以找到有效的jsbin here。我甚至添加了另一个条目来表明它正确排序。

您的代码可能无效,因为您返回布尔值而不是数字。我无法访问MDN的网站,但您可以看到引用here。您的函数应返回表示顺序的数字:

  

可选。定义替代排序顺序的函数。该   函数应返回负值,零值或正值,具体取决于   关于论点......