다음은 날짜 및 isImportant별로 정렬할 배열입니다. isImportant 속성이 true인 모든 개체는 isImportant가 false인 개체보다 순위가 높으며 두 그룹 모두 날짜 속성에 따라 정렬됩니다.
다음은 우리의 배열입니다 -
const array = [{ id: 545, date: 591020824000, isImportant: false, }, { id: 322, date: 591080224000, isImportant: false, }, { id: 543, bdate: 591080424000, isImportant: true, }, { id: 423, date: 591080225525, isImportant: false, }, { id: 135, date: 591020225525, isImportant: true, }, ];
그런 다음 위와 같은 배열 정렬 방법을 사용하여 위의 배열에서 원하는 결과를 얻을 수 있습니다 -
array.sort((a, b) => { if(a.isImportant && !b.isImportant){ return -1; }else if(!a.isImportant && b.isImportant){ return 1; }else{ return b.date-a.date; } });
sort() 콜백 함수는 일반적으로 두 개의 인수, 예를 들어 a 및 b를 수신합니다. 이는 sort()가 호출된 배열의 두 요소에 불과하며 콜백 함수는 배열의 가능한 각 요소 쌍에 대해 실행됩니다.
콜백에서 -1(음수 값)을 반환하면 첫 번째 요소의 순위를 두 번째보다 높게 지정합니다.
콜백에서 1(양수 값)을 반환한다는 것은 두 번째 요소의 순위를 첫 번째 요소보다 높게 지정한다는 의미입니다.
0을 반환하면 변경 사항이 없습니다. 또는 b 중 하나에 isImportant 속성이 tofalse로 설정되어 있는지 확인하고, 그렇다면 해당 항목의 순위를 낮춥니다. 그렇지 않으면 날짜 속성에 따라 순위를 매깁니다.
예시
이제 전체 예를 살펴보겠습니다 -
const array = [{ id: 545, date: 591020824000, isImportant: false, }, { id: 322, date: 591080224000, isImportant: false, }, { id: 543, bdate: 591080424000, isImportant: true, }, { id: 423, date: 591080225525, isImportant: false, }, { id: 135, date: 591020225525, isImportant: true, }, ]; array.sort((a, b) => { if(a.isImportant && !b.isImportant){ return -1; }else if(!a.isImportant && b.isImportant){ return 1; }else{ return b.date-a.date; } }); console.log(array);
출력
콘솔의 코드 출력은 다음과 같습니다. -
[ { id: 3, date: 591080424000, isImportant: true },{ id: 5, date: 591020225525, isImportant: true }, { id: 4, date: 591080225525, isImportant: false },{ id: 2, date: 591080224000, isImportant: false }, { id: 1, date: 591020824000, isImportant: false } ]