2016-06-16 8 views
26

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

Odpowiedz

66

documentation określa, że ​​można przekazać funkcję jako "iteratee":

[iteratees=[_.identity]] (Array[]|Function[]|Object[]|string[]): The iteratees to sort by.

Więc można zrobić

const users = [ 
 
    { name: 'A', age: 48 }, 
 
    { name: 'B', age: 34 }, 
 
    { name: 'b', age: 40 }, 
 
    { name: 'a', age: 36 } 
 
]; 
 

 
const sortedUsers = _.orderBy(users, [user => user.name.toLowerCase()], ['desc']); 
 
console.log(sortedUsers);
<script src="https://cdn.jsdelivr.net/lodash/4.13.1/lodash.min.js"></script>

+1

Może to nie działać w starszych przeglądarkach. – steampowered

+4

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. –

+0

Czy to działa z nazwami właściwości dynamicznych? – TheCaptan

Powiązane problemy