Sprawdziłem tę odpowiedź, ale aby osiągnąć ten sam wynik, to jest sortowanie bez rozróżniania wielkości liter, muszę użyć orderBy
zamiast, sortBy
ponieważ daje możliwość określenia kolejności sortowania .
Jedynym sposobem, w jaki udało mi się to osiągnąć, było utworzenie sklonowanej tablicy „środkowej” odwzorowanej na małe litery name
:
const users = [
{ name: 'A', age: 48 },
{ name: 'B', age: 34 },
{ name: 'b', age: 40 },
{ name: 'a', age: 36 }
];
let lowerCaseUsers = _.clone(users);
lowerCaseUsers = lowerCaseUsers.map((user) => {
user.name = user.name.toLowerCase();
return user;
});
const sortedUsers = _.orderBy(lowerCaseUsers, ['name'], ['desc']);
console.log(sortedUsers);
Wydaje się to naprawdę drogie, a nawet bardziej skomplikowane w przypadku wielu sortowań i nazw właściwości dynamicznych.
Czy jest lepszy pomysł?
Oto Plunker: https://plnkr.co/edit/i1ywyxjFctuNfHtPTcgG
javascript
lodash
WhiteEleven
źródło
źródło
const
navar
) pozostawię czytelnikowi jako ćwiczenie.const sortedUsers = _.orderBy(users, [user => user[propToSort].toLowerCase()], ['desc']);
.toString()
przed wywołaniem tam małych liter, dodatkowo jeśli chcesz użyćproperty.something
do propToSort i podobnych, możesz użyć_.get(user, propToSort)
(może to pomoże komuś innemu)Zamawianie według wielu właściwości:
const users = [ { name: 'A', age: 48 }, { name: 'B', age: 34 }, { name: 'b', age: 40 }, { name: 'a', age: 36 } ] const nameSorter = user => user.name.toLowerCase() const ageSorter = 'age' const sortedUsers = _.orderBy(users, [nameSorter, ageSorter], ['desc', 'asc'])
źródło
Możesz połączyć przykład Felixa Klinga z funkcją _.get, aby sortować według dynamicznych atrybutów zagnieżdżonych:
const _ = require('lodash'); let test = [{ a: {b:'AA'}},{a: {b:'BB'} }, {a: {b: 'bb'}}, {a:{b:'aa'}}]; let attrPath = 'a.b'; _.orderBy(test, [item => _.get(item, attrPath).toLowerCase()]);
źródło