Подтвердить что ты не робот

Функция сортировки сортировки Javascript - сортировка отсортированного массива

У меня есть массив объектов следующего вида:

arr[0] = { 'item1' : 1234, 'item2' : 'a string' };

Я сортирую его сначала 'item1', что является простым. Теперь я хочу снова отсортировать arr (который отсортирован по 'item1'), но на этот раз 'item2', но только для элементов, где 'item1' - то же самое. Окончательный массив будет выглядеть так:

arr = [
  { 'item1' : 1234, 'item2' : 'apple' },
  { 'item1' : 1234, 'item2' : 'banana' },
  { 'item1' : 1234, 'item2' : 'custard' },
  { 'item1' : 2156, 'item2' : 'melon' },
  { 'item1' : 4345, 'item2' : 'asparagus' } 
];

Я попытался написать функцию сортировки для второго так:

arr.sort(function(a,b){
  if(a.item1 === b.item1){
    return a.item2 > b.item2 ? 1 : a.item2 < b.item2 : -1 : 0;
  }
});

Я мог бы объединить два вида в одной функции, чтобы получить окончательный отсортированный массив, но будут случаи, когда мне придется сортировать только 'item1' или просто 'item2'.

4b9b3361

Ответ 1

У вас может быть четыре различные функции сравнения: одна сортировка по элементу 1, по одному - по пункту2, по одному - по пункту1, затем по пункту2 и по пункту2, затем по пункту 1.

например:.

arr.sort(function(a,b){
  if(a.item1 == b.item1){
    return a.item2 > b.item2 ? 1 : a.item2 < b.item2 ? -1 : 0;
  }

  return a.item1 > b.item1 ? 1 : -1;
});