다음과 같은 배열이 있습니다 -
const arr = [{ year: 2020, month: 'January' }, { year: 2017, month: 'March' }, { year: 2010, month: 'January' }, { year: 2010, month: 'December' }, { year: 2020, month: 'April' }, { year: 2017, month: 'August' }, { year: 2010, month: 'February' }, { year: 2020, month: 'October' }, { year: 2017, month: 'June' }]
이 배열을 연도에 따라 오름차순(오름차순)으로 정렬해야 합니다. 또한 같은 연도 속성을 가진 두 개의 개체가 있는 경우 해당 연도를 월에 따라 정렬해야 합니다(예:jan, 다음 feb, 다음 March 등).
따라서 이 정렬 문제에 대한 코드를 작성해 보겠습니다. 이에 대한 완전한 코드는 -
예시
const arr = [{ year: 2020, month: 'January' }, { year: 2017, month: 'March' }, { year: 2010, month: 'January' }, { year: 2010, month: 'December' }, { year: 2020, month: 'April' }, { year: 2017, month: 'August' }, { year: 2010, month: 'February' }, { year: 2020, month: 'October' }, { year: 2017, month: 'June' }] const months = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']; const sorter = (a, b) => { if(a.year !== b.year){ return a.year - b.year; }else{ return months.indexOf(a.month) - months.indexOf(b.month); }; }; arr.sort(sorter); console.log(arr);
연도가 다른지 확인하고 연도별로 정렬하지만 연도가 같으면 정의한 사용자 지정 월 배열을 사용하여 월을 확인하고 이와 같이 연도가 같은 개체를 월별로 정렬합니다.
출력
콘솔의 출력은 -
[ { year: 2010, month: 'January' }, { year: 2010, month: 'February' }, { year: 2010, month: 'December' }, { year: 2017, month: 'March' }, { year: 2017, month: 'June' }, { year: 2017, month: 'August' }, { year: 2020, month: 'January' }, { year: 2020, month: 'April' }, { year: 2020, month: 'October' } ]