공유 키를 사용하여 배열의 JavaScript 개체를 병합하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-10-30 23:43:30
원래의
909명이 탐색했습니다.

How to Merge JavaScript Objects in an Array with Shared Keys?

공유 키를 사용하여 배열의 JavaScript 개체 병합

JavaScript에서는 유사한 키를 가진 개체를 단일 개체로 결합해야 하는 경우가 많습니다. . 주어진 예를 고려하십시오.

<code class="js">const array = [
  {
    name: "foo1",
    value: "val1"
  },
  {
    name: "foo1",
    value: ["val2", "val3"]
  },
  {
    name: "foo2",
    value: "val4"
  }
];</code>
로그인 후 복사

이 배열을 모든 값 키가 공유 이름을 가진 객체로 병합되는 "출력" 배열로 재구성하는 것이 목표입니다. 예상되는 출력은 다음과 같습니다.

<code class="js">const output = [
  {
    name: "foo1",
    value: ["val1", "val2", "val3"]
  },
  {
    name: "foo2",
    value: ["val4"]
  }
];</code>
로그인 후 복사

개체 병합

이 문제에 대한 한 가지 접근 방식은 다음 단계를 사용하는 것입니다.

  1. forEach()를 사용하여 배열의 각 개체를 반복합니다.
  2. 출력 배열을 필터링하여 동일한 이름의 키를 가진 기존 개체를 찾습니다.
  3. 기존 개체가 발견되면 현재 객체의 값을 해당 값 배열에 추가합니다.
  4. 기존 객체를 찾을 수 없는 경우 현재 객체의 속성으로 새 객체를 생성하여 출력 배열에 추가합니다.
  5. 가능성을 처리합니다. 값을 배열로 변환하여 문자열로 변환합니다.

예제 코드

다음 코드는 설명된 접근 방식을 구현합니다.

<code class="js">const array = [
  {
    name: "foo1",
    value: "val1"
  },
  {
    name: "foo1",
    value: ["val2", "val3"]
  },
  {
    name: "foo2",
    value: "val4"
  }
];

let output = [];

array.forEach(item => {
  const existing = output.filter(v => v.name == item.name);
  if (existing.length) {
    const existingIndex = output.indexOf(existing[0]);
    output[existingIndex].value = output[existingIndex].value.concat(item.value);
  } else {
    if (typeof item.value == 'string') item.value = [item.value];
    output.push(item);
  }
});

console.log(output);</code>
로그인 후 복사

이 코드는 동일한 이름을 가진 모든 객체의 값이 병합된 원하는 출력 배열을 생성합니다.

위 내용은 공유 키를 사용하여 배열의 JavaScript 개체를 병합하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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