с массивом, подобным этому:
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 полям.