jQuery를 사용하여 속성별로 개체 배열을 그룹화하고 합산하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-17 07:51:03
원래의
469명이 탐색했습니다.

How to Group and Sum an Array of Objects by a Property Using jQuery?

객체 배열을 속성별로 그룹화 및 합산

문제

객체 배열이 주어지면, 목표는 특정 객체별로 그룹화하는 것입니다. Id와 같은 속성을 계산하고 jQuery를 사용하여 각 그룹에 대해 qty와 같은 다른 속성의 합을 계산합니다.

다음 입력 배열을 고려하세요.

var array = [
  { Id: "001", qty: 1 },
  { Id: "002", qty: 2 },
  { Id: "001", qty: 2 },
  { Id: "003", qty: 4 }
];
로그인 후 복사

원하는 출력은 다음과 같습니다.

[
  { Id: "001", qty: 3 },
  { Id: "002", qty: 2 },
  { Id: "003", qty: 4 }
]
로그인 후 복사

해결책

ID별로 배열을 그룹화하고 jQuery를 사용하여 각 그룹의 수량 값을 합산하려면 다음 접근 방식을 사용할 수 있습니다.

$(array).groupBy('Id').reduce(function (res, obj) {
  return res + obj.qty;
}, 0);
로그인 후 복사

솔루션 분석은 다음과 같습니다.

  • jQuery의 groupBy 플러그인: 이 플러그인은 지정된 속성인 ID를 기준으로 개체 배열을 그룹화합니다. 고유한 ID 값에 해당하는 속성 키가 있는 객체를 반환합니다.
  • jQuery의 축소 메서드: 이 메서드는 그룹화된 개체를 반복하고 지정된 콜백 함수를 적용하여 수량 값의 합계를 계산합니다. 각 그룹마다. 이 경우 콜백 함수는 단순히 각 객체의 qty 속성을 누산기에 추가합니다.

위 내용은 jQuery를 사용하여 속성별로 개체 배열을 그룹화하고 합산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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