169 похожих чатов

Не знаю, попробуй: function compare(names) { var len

= arguments.length;
var fields, orders;
if (typeof names === 'object') {
fields = Object.getOwnPropertyNames(names);
orders = fields.map(key => names[key]);
len = fields.length;
} else {
fields = new Array(len);
for(let i = len; i--;) fields[i] = arguments[i];
orders = (new Array(len)).fill(1);
}
return (a, b) => {
for (let i = 0; i < len; i++) {
if (a[fields[i]] === undefined && b[fields[i]] !== undefined) return !!b[fields[i]] ? orders[i] : -orders[i];
if (b[fields[i]] === undefined && a[fields[i]] !== undefined) return !!a[fields[i]] ? -orders[i] : orders[i];
if (a[fields[i]] < b[fields[i]]) return orders[i];
if (a[fields[i]] > b[fields[i]]) return -orders[i];
}
return 0;
};
}

var arr = [{"suspend":true,}, {"open":true, "val": 1,},{"cancel":true,}, {"open":true, "val":2}, {"suspend": false}];
var arr2 = arr.sort(compare('open', 'suspend', 'cancel'));
arr2 = arr.sort(compare(['open', 'suspend', 'cancel']));
var arr3 = arr.sort(compare({"open": 1, "suspend": -1, "cancel": 1}));

1 ответов

19 просмотров

Ого, спасибо. Я чуть проще сделал - по длине сравнил и там где 'open', сделал "чуть длиннее", получилось в одну длинную строку: list.sort((a, b) => { return (a.status_code.length === 4 ? 8 : a.status_code.length) > (b.status_code.length === 4 ? 8 : b.status_code.length) ? -1 : 1 })

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта