자바스크립트 reduce() 메소드
6845 단어 javascript
reduce()
메서드를 살펴봅니다.reduce 메소드는 배열을 하나의 특정 단일 값으로 변환하는 데 사용할 수 있습니다.
Also, check out my article on the JavaScript filter() method
자바스크립트 reduce() 메소드 사용
감소는 예를 들어 총계를 계산하는 데 사용할 수 있습니다. 다음과 같은 배열이 있다고 가정해 보겠습니다.
const items = [
{ name: 'T-shirt plain', price: 9 },
{ name: 'T-shirt print', price: 20 },
{ name: 'Jeans', price: 30 },
{ name: 'Cap', price: 5 }
];
이제 어떻게 이 모든 항목의 총계를 얻을 수 있습니까?
const reduced = items.reduce((total, item) => {
total += item.price;
return total;
}, 0);
// 64
여기서 우리가 하는 것은
total
인수를 제공하는 것입니다. 이것은 initialValue
이고, 다음 인수는 currentValue
이며 총 가치에 가격을 더합니다.그런 다음 끝에
0
가 정의된 것을 볼 수 있습니다. 이것은 initialValue
기본값입니다.reduce
에 대한 인수는 다음과 같습니다.const new = original.reduce(function(total, current, index, array), initialValue);
다음이 적용되는 경우:
total
: 필수, 초기값current
: 필수, 현재 인덱스 값index
: 선택 사항, 현재 행의 배열 인덱스array
: 선택 사항, 현재 행이 속한 배열. initialValue
: 선택 사항, 시작점으로 정의할 값입니다. 물론 특정 항목만 계산할 수도 있습니다. 할인된 항목이 있고 그 항목만 계산하려고 한다고 가정해 보겠습니다.
const items = [
{ name: 'T-shirt plain', price: 9, discount: true },
{ name: 'T-shirt print', price: 20, discount: false },
{ name: 'Jeans', price: 30, discount: true },
{ name: 'Cap', price: 5, discount: false }
];
const reduced = items.reduce((total, item) => {
if(item.discount)
total += item.price;
return total;
}, 0);
// 39
보시다시피 매우 강력하지만 구현하기 쉬운 방법입니다. 실제로 많은 루프 논리를 줄입니다.
읽어주셔서 감사합니다. 연결해 보겠습니다!
제 블로그를 읽어주셔서 감사합니다. 내 이메일 뉴스레터를 구독하고 Facebook 또는
Reference
이 문제에 관하여(자바스크립트 reduce() 메소드), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/dailydevtips1/javascript-reduce-function-bd0텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)