>웹 프론트엔드 >JS 튜토리얼 >중첩된 값을 기반으로 하는 배열로 개체 배열을 필터링하는 방법은 무엇입니까?

중첩된 값을 기반으로 하는 배열로 개체 배열을 필터링하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-29 03:08:02265검색

How to Filter an Array of Objects with Arrays Based on Nested Value?

중첩 값 기반 배열로 객체 배열 필터링

질문: 중첩 값을 기반으로 객체 배열을 필터링하려면 어떻게 해야 하나요?

입력:

<code class="javascript">let arrayOfElements = [
    {
        "name": "a",
        "subElements": [
            {"surname": 1},
            {"surname": 2}
        ]
    },
    {
        "name": "b",
        "subElements": [
            {"surname": 3},
            {"surname": 1}
        ]
    },
    {
        "name": "c",
        "subElements": [
            {"surname": 2},
            {"surname": 5}
        ]
    }
];</code>

원하는 출력:

<code class="javascript">let filteredArray = [
    {
        "name": "a",
        "subElements": [
            {"surname": 1}
        ]
    },
    {
        "name": "b",
        "subElements": [
            {"surname": 1}
        ]
    }
];</code>

초기 시도:

<code class="javascript">let filteredArray = arrayOfElements.filter((element) => element.subElements.some((subElement) => subElement.surname === 1));</code>

문제: 이 접근 방식은 개체를 잘라내는 대신 모든 성이 포함된 개체를 반환합니다.

해결책:

<code class="javascript">arrayOfElements.map((element) => {
    return {...element, subElements: element.subElements.filter((subElement) => subElement.surname === 1)}
})</code>

설명:

  • 이 접근 방식은 map() 메서드를 사용하여 arrayOfElements를 반복합니다.
  • 각 요소에 대해 해당 속성을 새 객체입니다.
  • 그런 다음 하위 요소 배열에서 필터()를 사용하여 조건(성 === 1)을 충족하는 항목만 유지합니다.
  • 그런 다음 필터링된 하위 요소를 사용하여 원래 하위 요소 배열.

위 내용은 중첩된 값을 기반으로 하는 배열로 개체 배열을 필터링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.