> 웹 프론트엔드 > JS 튜토리얼 > 바닐라 접근 방식을 사용하여 JavaScript에서 개체 배열을 효율적으로 그룹화하려면 어떻게 해야 합니까?

바닐라 접근 방식을 사용하여 JavaScript에서 개체 배열을 효율적으로 그룹화하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-12-30 12:31:13
원래의
285명이 탐색했습니다.

How Can I Efficiently Group an Array of Objects in JavaScript Using a Vanilla Approach?

객체 배열을 위한 효율적인 GroupBy 방법

공통 속성을 기반으로 객체를 그룹화하는 것은 데이터 처리에서 일반적인 작업입니다. 이 스니펫은 바닐라 JavaScript 접근 방식을 사용하여 배열의 개체를 그룹화하는 효율적인 솔루션을 제공합니다.

Underscore.js를 피하는 이유

Underscore.js는 groupBy 기능을 제공하지만 구현은 그렇지 않을 수 있습니다. 별도의 그룹이 아닌 "병합된" 결과가 필요한 경우에 적합합니다.

Custom Vanilla JS GroupBy

다음 스크립트는 객체 배열에서 작동하는 groupBy 함수를 정의합니다.

var groupBy = function(xs, key) {
  return xs.reduce(function(rv, x) {
    (rv[x[key]] = rv[x[key]] || []).push(x);
    return rv;
  }, {});
};
로그인 후 복사

사용 예

"단계"별로 객체를 그룹화하려면:

const data = [
  { Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" },
  ...
];
const groupedByPhase = groupBy(data, 'Phase');
로그인 후 복사

groupedByPhase는 포함:

{
  "Phase 1": [
    { Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" },
    ...
  ],
  "Phase 2": [
    { Phase: "Phase 2", Step: "Step 1", Task: "Task 1", Value: "25" },
    ...
  ]
}
로그인 후 복사

"Step"으로 추가 그룹화:

const groupedByPhaseStep = _(groupedByPhase).values().map(phase => {
  return groupBy(phase, 'Step');
}).value();
로그인 후 복사

groupedByPhaseStep에는 다음이 포함됩니다:

[
  {
    "Phase": "Phase 1",
    "Step": "Step 1",
    "Value": 15
  },
  ...
]
로그인 후 복사

위 내용은 바닐라 접근 방식을 사용하여 JavaScript에서 개체 배열을 효율적으로 그룹화하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿