Sprawdziłem this answer, ale aby uzyskać ten sam wynik, czyli sortowanie bez rozróżniania wielkości liter, muszę użyć orderBy
zamiast sortBy
od daje możliwość określenia kolejności sortowania.Lodash: jak zrobić sortowanie niewrażliwe na wielkość kolekcji za pomocą polecenia orderBy?
Jedynym sposobem znalazłem to osiągnąć było stworzenie sklonowanego „middle” tablicę odwzorowaną 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ę bardzo drogie i to nawet bardziej skomplikowane z wieloma dobieranie i nazwy właściwości dynamicznych.
Czy jest lepszy pomysł?
Oto Plunker: https://plnkr.co/edit/i1ywyxjFctuNfHtPTcgG
Może to nie działać w starszych przeglądarkach. – steampowered
Jeśli masz na myśli to, że spowoduje to błąd składni w przeglądarce, która nie obsługuje ES6, a więc tak, oczywiście. Zostawię konwersję funkcji strzałki na "normalną" funkcję (i 'const' na' var') jako ćwiczenie dla czytnika. –
Czy to działa z nazwami właściwości dynamicznych? – TheCaptan