为了账号安全,请及时绑定邮箱和手机立即绑定

如何通过Javascript按3列对数组进行排序?

如何通过Javascript按3列对数组进行排序?

杨__羊羊 2022-08-27 14:52:41
我正在尝试按三列对数组进行排序。下面是我的示例数组。有时,该列也可以为空,因此我在排序函数中进行了检查。但是,现在我想先对名称进行排序,然后是薪水,然后是奖金。我怎样才能做到这一点?let employees = [    {name: 'John', salary: 90000, bonus: 1000},    {name: 'David', salary: 90000, bonus: 1200},    {name: 'Ana', salary: 80000, bonus: 3000}];// Code for sorting salary first and then bonus:function sort(a,b) {  if (a.salary=== null && b.salary=== null ){    return a.bonus- b.bonus;  }   else if (a.salary!== null && b.salary=== null ){    return -1;  }  else if (a.salary=== null && b.salary!== null){    return 1;  }else if (a.salary!== null && b.salary!== null){    return a.salary- b.salary;  }  else {    return 1;  }}employees.sort(sort);console.log(employees);
查看完整描述

3 回答

?
慕丝7291255

TA贡献1859条经验 获得超6个赞

只需返回第一个非零比较值。我还确保任何不是数字的东西都会被排序在最后,但如果你确定你只会得到一个有效的数字,或者你可以简化检查。null


const employees = [

    {name: 'Ana', salary: null, bonus: 3000},

    {name: 'Ana', salary: 80000, bonus: 3000},

    {name: 'Ana', salary: 70000, bonus: 3000},

    {name: 'Ana', salary: 70000, bonus: 1000}

];


employees.sort((a, b) => {

  return a.name.localeCompare(b.name) ||

    safeNumCompare(a.salary, b.salary) ||

    safeNumCompare(a.bonus, b.bonus);

});


console.log(employees);


function safeNumCompare(a, b) {

  const aValid = isValidNum(a), bValid = isValidNum(b);


  if (!(aValid || bValid)) return 0;

  if (!aValid) return 1;

  if (!bValid) return -1;

  return a - b;

}


function isValidNum(num) {

  return typeof num === 'number' && !isNaN(num);

}


查看完整回答
反对 回复 2022-08-27
?
繁花不似锦

TA贡献1851条经验 获得超4个赞

您可以使用以下逻辑:

  • 排序需要返回一个数值。因此,您可以使用算术运算。

  • 您的值可以是 ,因此最好是默认值。null

    • 0用于升序

    • Infinity用于降序

  • 执行升序操作。a - b

  • 对于优先级下降,请使用,以便如果第一个方程返回 0,它将检查下一个优先级||

注意:

上述逻辑将按姓名升序排序,然后是工资,然后是奖金。因此,如果两个用户的薪水相同,那么他们的奖金将以这种方式进行检查和排序。

let employees = [{ name: 'John', salary: 90000, bonus: 1000 }, { name: 'David', salary: 90000, bonus: 1200}, { name: 'David',  salary: null,  bonus: 1200}, {  name: 'Ana',  salary: 80000,  bonus: 3000}, {  name: 'Ana',  salary: 80000,  bonus: null }];


function sort(a, b) {

  return (a.name.localeCompare(b.name)) ||

    ((a.salary || Infinity) - (b.salary || Infinity)) ||

    ((a.bonus || 0) - (b.bonus || 0));

}


employees.sort(sort);

console.log(employees);

正如 plalx 所正确建议的那样

他希望最后排序的 null,也希望按名称排在最后。

因此用于默认Infinitysalary


查看完整回答
反对 回复 2022-08-27
?
婷婷同学_

TA贡献1844条经验 获得超8个赞

有一个名为lodash的npm包。您可以使用其 sortBy 方法实现所需的功能。


const _ = require('lodash');


let employees = [

    {name: 'John', salary: 90000, bonus: 1000},

    {name: 'David', salary: 90000, bonus: 1200},

    {name: 'Ana', salary: 80000, bonus: 3000}

];


const sortedArray = _.sortBy(employees, ['name', 'salary', 'bonus']);

我希望它有帮助。


查看完整回答
反对 回复 2022-08-27
  • 3 回答
  • 0 关注
  • 151 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号