배열 객체를 동일한 ID로 유형별로 병합하고 JavaScript를 사용하여 금액을 할당하는 방법은 무엇입니까?
이 기사에서는 JavaScript를 사용하여 배열을 처리하고 동일한 ID의 객체를 새 개체로 병합하고 다른 유형 (아침 식사, 중국어, 저녁 식사)에 따라 다른 필드에 양을 할당하는 방법에 대해 설명합니다.
id
, jine
(양) 및 type
(유형) 필드가있는 여러 개체 배열이 있다고 가정합니다. 목표는 이러한 데이터를 다른 형식으로 변환하는 것인데, 여기서 각 id
에 해당하는 데이터가 하나의 객체로 병합되고 jine
값은 type
에 따라 jine1
(아침 식사), jine2
(중국 음식) 및 jine3
(저녁) 필드에 할당됩니다.
원시 데이터 :
const list = [ {id : "202301", Jine : 23, type : "dinner"}, {id : "202301", Jine : 87.5, 유형 : "아침 식사"}, {id : "202301", Jine : 1065.5, 유형 : "Chinese Food"}, {id : "202302", Jine : 10, type : "dinner"}, {id : "202302", Jine : 181.5, 유형 : "아침 식사"}, {id : "202302", Jine : 633.5, 유형 : "중국 음식"} ];
대상 형식 :
const expectlist = [ {id : "202301", jine1 : 87.5, jine2 : 1065.5, jine3 : 23}, {id : "202302", Jine1 : 181.5, Jine2 : 633.5, jine3 : 10} ];
이를 달성하기 위해 reduce
방법을 사용하여 배열을 반복하고 새로운 객체를 만들어 결과를 저장할 수 있습니다.
해결책:
const result = object.values (list.reduce ((acc, curr) => { if (! acc [curr.id]) { acc [curr.id] = {id : curr.id, jine1 : 0, jine2 : 0, jine3 : 0}; } if (curr.type === 'Breakfast') acc [curr.id] .jine1 = curr.jine; if (curr.type === '중국 음식') acc [curr.id] .jine2 = curr.jine; if (curr.type === 'dinner') acc [curr.id] .jine3 = curr.jine; 반환 ACC; }, {})); Console.log (결과); // 대상 형식의 출력 배열
이 코드는 먼저 reduce
메소드를 사용하여 원래 배열을 객체로 변환하고 키는 id
이며 값은 jine1
, jine2
및 jine3
포함하는 객체입니다. 그런 다음 Object.values
를 사용하여 객체를 배열로 변환합니다. reduce
방법에서는 현재 id
acc
에 존재하는지 여부를 확인하고, 존재하지 않는 경우 새 개체를 생성하고, type
에 따라 해당 필드에 jine
값을 할당합니다.
이 방법은 Object.groupBy
의 사용을 피하고 Groupby 및 메소드를 find
코드의 가독성과 효율성을 향상 시키며 데이터 병합 및 금액 할당을보다 직접 처리합니다. find
메소드가 정의되지 undefined
반환 될 수있는 경우를 처리 할 필요가 없기 때문에 더욱 강력합니다.
위 내용은 배열 객체를 동일한 ID로 유형별로 병합하고 JavaScript를 사용하여 금액을 할당하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 개발에서 PHP의 CURL 라이브러리를 사용하여 JSON 데이터를 보내면 종종 외부 API와 상호 작용해야합니다. 일반적인 방법 중 하나는 컬 라이브러리를 사용하여 게시물을 보내는 것입니다 ...

Docker 환경을 사용할 때 Docker 환경에 Extensions를 설치하기 위해 PECL을 사용하여 오류의 원인 및 솔루션. 종종 일부 두통이 발생합니다 ...

Linux 터미널에서 Python 사용 ...

이 기사는 데비안 시스템에서 PostgresQL 데이터베이스를 모니터링하는 다양한 방법과 도구를 소개하여 데이터베이스 성능 모니터링을 완전히 파악할 수 있도록 도와줍니다. 1. PostgreSQL을 사용하여 빌드 인 모니터링보기 PostgreSQL 자체는 데이터베이스 활동 모니터링 활동을위한 여러보기를 제공합니다. PG_STAT_REPLICATION : 특히 스트림 복제 클러스터에 적합한 복제 상태를 모니터링합니다. PG_STAT_DATABASE : 데이터베이스 크기, 트랜잭션 커밋/롤백 시간 및 기타 주요 지표와 같은 데이터베이스 통계를 제공합니다. 2. 로그 분석 도구 PGBADG를 사용하십시오

DebianHadoop 클러스터의 성능을 향상 시키려면 하드웨어, 소프트웨어, 리소스 관리 및 성능 튜닝에서 시작해야합니다. 다음은 몇 가지 주요 최적화 전략 및 제안입니다. 1. 하드웨어 및 시스템 구성 선택 하드웨어 구성을 선택하십시오. 하드웨어 구성을 선택하십시오. 실제 애플리케이션 시나리오에 따라 적절한 CPU, 메모리 및 스토리지 장치를 선택하십시오. SSD 가속 I/O : I/O 작동 속도를 향상시키기 위해 가능한 한 SSD (Solid State Hard Drive)를 사용하십시오. 메모리 확장 : 더 큰 데이터 처리 및 작업에 대처하기 위해 Namenode 및 Datanode 노드에 충분한 메모리를 할당합니다. 2. 소프트웨어 구성 최적화 Hadoop 구성 파일 조정 : Core-Site.xml : HDFS 기본 파일 시스템 구성

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...
