> 웹 프론트엔드 > JS 튜토리얼 > 여러 JavaScript 배열의 특정 속성 값을 효율적으로 합산하려면 어떻게 해야 합니까?

여러 JavaScript 배열의 특정 속성 값을 효율적으로 합산하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-12-20 19:34:10
원래의
1055명이 탐색했습니다.

How Can I Efficiently Sum the Values of a Specific Property Across Multiple JavaScript Arrays?

효율적인 배열 값 합산

이 질문은 여러 배열에 걸쳐 특정 속성의 총합을 계산하기 위한 효율적인 솔루션을 찾습니다.

문제 명령문

각각 "설명" 및 "금액" 속성이 포함된 개체 배열이 있는 경우 원래 접근 방식에서는 배열을 반복하고 "금액" 값을 점진적으로 추가하는 작업이 포함되었습니다.

$scope.totalAmount = function(){
       var total = 0;
       for (var i = 0; i < $scope.traveler.length; i++) {
              total = total + $scope.traveler[i].Amount;
            }
       return total;
}
로그인 후 복사

임의의 성질에 대한 등가법

원하는 해법

$scope.traveler.Sum({ Amount });
$scope.someArray.Sum({ someProperty });
로그인 후 복사

최적화된 솔루션

제안된 솔루션은 이를 달성하기 위해 array.reduce 메서드를 활용합니다. 목표:

$scope.sum = function(items, prop){
    return items.reduce( function(a, b){
        return a + b[prop];
    }, 0);
};

$scope.travelerTotal = $scope.sum($scope.traveler, 'Amount');
로그인 후 복사

장점

  • 재사용성: 이 솔루션은 적절한 인수를 전달하여 모든 배열에 재사용할 수 있습니다. 합계 함수.
  • 간결함: 단일 방법으로 합산 논리를 캡슐화하여 명시적인 반복 루프가 필요하지 않습니다.
  • 향상된 성능: Reduce는 배열 처리에 대한 고유한 성능 최적화를 제공합니다.

위 내용은 여러 JavaScript 배열의 특정 속성 값을 효율적으로 합산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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