亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何通過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 關注
  • 120 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號