Как отсортировать только несколько элементов в массиве объекта по свойству даты

#javascript #sorting

#javascript #сортировка

Вопрос:

У меня есть массив объектов, как показано ниже.

 var array = [{id: 1, date:'Mar 12 2012 10:00:00 AM', status:'done'}, 
                 {id: 2, date:'Mar 8 2012 08:00:00 AM', status:'done'},
                 {id: 3, date:'Mar 15 2012 10:00:00 AM', status:'done'}, 
                 {id: 4, date:'Mar 5 2012 08:00:00 AM', status:'done'},
                 {id: 5, date:'Mar 30 2012 10:00:00 AM', status:'done'}, 
                 {id: 6, date:'Mar 5 2012 08:00:00 AM', status:'done'},
                 {id: 7, date:'Mar 1 2012 10:00:00 AM', status:'done'}, 
                 {id: 8, date:'Mar 7 2012 08:00:00 AM', status:'notdone'},
                 {id: 9, date:'Mar 12 2012 10:00:00 AM', status:'notdone'}, 
                 {id: 10, date:'Mar 2 2012 10:00:00 AM', status:'notdone'}, 
                 {id: 11, date:'Mar 6 2012 10:00:00 AM', status:'notexist'}, 
                 {id: 12, date:'Mar 8 2012 08:00:00 AM', status:'notexist'}];
 

Я пытаюсь отсортировать первые несколько элементов в моем массиве, которые есть status:'done' , и оставить оставшиеся записи как есть.

Может кто-нибудь помочь мне с тем, как я могу поставить это условие и sort элементы.

Спасибо.

Комментарии:

1. То, что никто не говорит вам в приведенных ниже ответах, заключается в том, что подход, который они используют для создания Date объекта из строки, сопряжен с рисками. См. MDN для получения дополнительной информации.

Ответ №1:

 var array = [{id: 1, date:'Mar 12 2012 10:00:00 AM', status:'done'}, 
                 {id: 2, date:'Mar 8 2012 08:00:00 AM', status:'done'},
                 {id: 3, date:'Mar 15 2012 10:00:00 AM', status:'done'}, 
                 {id: 4, date:'Mar 5 2012 08:00:00 AM', status:'done'},
                 {id: 5, date:'Mar 30 2012 10:00:00 AM', status:'done'}, 
                 {id: 6, date:'Mar 5 2012 08:00:00 AM', status:'done'},
                 {id: 7, date:'Mar 1 2012 10:00:00 AM', status:'done'}, 
                 {id: 8, date:'Mar 7 2012 08:00:00 AM', status:'notdone'},
                 {id: 9, date:'Mar 12 2012 10:00:00 AM', status:'notdone'}, 
                 {id: 10, date:'Mar 2 2012 10:00:00 AM', status:'notdone'}, 
                 {id: 11, date:'Mar 6 2012 10:00:00 AM', status:'notexist'}, 
                 {id: 12, date:'Mar 8 2012 08:00:00 AM', status:'notexist'}];
                 
var doneItems = array.filter(r => r.status === 'done');
var remainingItems = array.filter(r => r.status !== 'done');

doneItems.sort((a, b) => (new Date(a.date) - new Date(b.date)));

console.log(doneItems.concat(remainingItems)); 

Комментарии:

1. @brig Это отвечает на ваш вопрос? Дайте мне знать, если вам нужна какая-либо помощь

Ответ №2:

 const sorted = array.reduce((prev, curr, i, xs) => {
  // push into either the first or second sub-array based on status
  const idx = curr.status === 'done' ? 0 : 1
  prev[idx].push(curr)

  // if on the last element, sort the first array
  // the check is just to avoid running the sort on every iteration
  if (i === xs.length - 1) {
    prev[0].sort((a, b) => new Date(a.date) - new Date(b.date))
  }

  return prev

// initialize with a 2d array, flatten when it's all done
}, [[],[]]).flat()
 

Ответ №3:

Все в одном решении:

 array.sort(function(a, b) {
    if (a.status === 'done' amp;amp; b.status === 'done') {
        return new Date(a.date) - new Date(b.date);
    } else if (a.status === 'done') {
        return -1;
    } else if (b.status === 'done') {
        return 1;
    }
});
 

Ответ №4:

Вы можете сначала отфильтровать по статусу, а затем отсортировать по дате:

 var array = [{id: 1, date:'Mar 12 2012 10:00:00 AM', status:'done'}, 
                 {id: 2, date:'Mar 8 2012 08:00:00 AM', status:'done'},
                 {id: 3, date:'Mar 15 2012 10:00:00 AM', status:'done'}, 
                 {id: 4, date:'Mar 5 2012 08:00:00 AM', status:'done'},
                 {id: 5, date:'Mar 30 2012 10:00:00 AM', status:'done'}, 
                 {id: 6, date:'Mar 5 2012 08:00:00 AM', status:'done'},
                 {id: 7, date:'Mar 1 2012 10:00:00 AM', status:'done'}, 
                 {id: 8, date:'Mar 7 2012 08:00:00 AM', status:'notdone'},
                 {id: 9, date:'Mar 12 2012 10:00:00 AM', status:'notdone'}, 
                 {id: 10, date:'Mar 2 2012 10:00:00 AM', status:'notdone'}, 
                 {id: 11, date:'Mar 6 2012 10:00:00 AM', status:'notexist'}, 
                 {id: 12, date:'Mar 8 2012 08:00:00 AM', status:'notexist'}];
 
let filtered = array.filter(x => x.status == 'done') ;
let sorted = filtered.sort((a, b) => new Date(a.date) - new Date(b.date));
console.log(sorted)

// concat the 'non done' status items:
let rest = array.filter(x => x.status != 'done');
console.log(sorted.concat(rest))