с таким массивом:
users = [
{ id: 1, fname: 'Fred', lname: 'Flinstone', state: 'CA' },
{ id: 2, fname: 'George', lname: 'Winston', state: 'FL' },
{ id: 3, fname: 'Luke', lname: 'Skywalker', state: 'CA' }
]
и вы хотите отсортировать по фамилии с помощью coffeescript, вы можете сделать это:
users.sort (a,b) ->
return if a.lname.toUpperCase() >= b.lname.toUpperCase() then 1 else -1
Я пытался использовать такую функцию, как эта:
sortBy = (field, reverse, primer) ->
key = (x) ->
return if primer? then primer x[field] else x[field]
return (a,b) ->
A = key a
B = key b
return (A < B ? -1 : (A > B ? 1 : 0)) * [1,-1][+!!reverse]
, который был вызван следующим образом:
users.sort sortBy "lname", false, (a) ->
return a.toUpperCase()
, но не отсортировал массив должным образом.
Есть ли способ сортировки более чем на1 поле, т.е. сортировка сначала по Штату, а затем по Фамилии?Я надеялся улучшить описанную выше функцию «sortBy» и добавить возможность сортировки по крайней мере на 2 поля.