#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))