= 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}));
Ого, спасибо. Я чуть проще сделал - по длине сравнил и там где '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 })
Обсуждают сегодня