3 回答

TA貢獻(xiàn)1859條經(jīng)驗(yàn) 獲得超6個(gè)贊
只需返回第一個(gè)非零比較值。我還確保任何不是數(shù)字的東西都會(huì)被排序在最后,但如果你確定你只會(huì)得到一個(gè)有效的數(shù)字,或者你可以簡(jiǎn)化檢查。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);
}

TA貢獻(xiàn)1851條經(jīng)驗(yàn) 獲得超4個(gè)贊
您可以使用以下邏輯:
排序需要返回一個(gè)數(shù)值。因此,您可以使用算術(shù)運(yùn)算。
您的值可以是 ,因此最好是默認(rèn)值。
null
0
用于升序Infinity
用于降序執(zhí)行升序操作。
a - b
對(duì)于優(yōu)先級(jí)下降,請(qǐng)使用,以便如果第一個(gè)方程返回 0,它將檢查下一個(gè)優(yōu)先級(jí)
||
注意:
上述邏輯將按姓名升序排序,然后是工資,然后是獎(jiǎng)金。因此,如果兩個(gè)用戶的薪水相同,那么他們的獎(jiǎng)金將以這種方式進(jìn)行檢查和排序。
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,也希望按名稱排在最后。
因此用于默認(rèn)Infinity
salary

TA貢獻(xiàn)1844條經(jīng)驗(yàn) 獲得超8個(gè)贊
有一個(gè)名為lodash的npm包。您可以使用其 sortBy 方法實(shí)現(xiàn)所需的功能。
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']);
我希望它有幫助。
添加回答
舉報(bào)