티스토리 뷰
Frontend/JavaScript
[JavaScript | Array] .reduce() / .fill() / .map()
blueprint-12 2022. 5. 14. 17:51Array.prototype.reduce()
- reduce() 메소드는 배열의 각 요소에 대해 주어진 리듀서(reducer)함수를 실행하고, 하나의 결과값을 반환
- 각각의 배열 요소에 콜백함수를 실행하고 결과를 누적한 최종 답이 필요할 때 유용함 (e.g.배열 요소의 전체 합을 구할 때)
const array1 = [1, 2, 3, 4];
// 0 + 1 + 2 + 3 + 4
const initialValue = 0;
const sumWithInitial = array1.reduce(
(previousValue, currentValue) => previousValue + currentValue,
initialValue
);
console.log(sumWithInitial);
// expected output: 10
리듀서 함수(콜백함수)의 인자 4개
-optional 은 자주 안쓰임 특히 원본배열은 거의 안 쓰이는 듯, 필요할 때 콜백함수의 인자로 넘겨주면 된다.
-optional 은 말만 옵션이지 넣어주는 쪽이 좋음
🌞누산기 (acc)
- accumulator(누산기) - 콜백의 반환값을 누적한다. 콜백의 이전 반환값 or 콜백의 첫 번째 호출이면서 initialValue를 제공하는 경우에는 initialValue의 값이다.
- 맥락상 이전 값이라고 생각하면 된다. previous value(하지만 이제 첫번째를 빼면 누적이 된 이전 값..)
🌞현재 값(curr)
- 처리할 현재 요소
- 맥락상 현재 처리할 값이라고 생각하면 된다. current value
🌞현재 인덱스(idx) optional
- 처리할 현재 요소의 인덱스 initialValue를 제공한 경우 0, 아니면 1부터 시작한다.
🌞원본 배열(src) optional
🌚초기 값(initialValue) optional
- 얘는 콜백의 인자가 아님 콜백함수의 초기값임 그렇기 때문에 아래와 같이 작성
var sum = [0, 1, 2, 3].reduce(function (accumulator, currentValue) {
return accumulator + currentValue;
}, 0);
// sum is 6
- 콜백의 최초 호출에서 첫 번째 인수에 제공하는 값. 초기값을 제공하지 않으면 배열의 첫 번째 요소를 사용한다)인덱스 0을 초기값으로 세팅) .
- 초기값을 제공하지 않으면 reduce()는 인덱스 1부터 시작해 콜백함수를 실행하고 첫 번째 인덱스는 건너 뛴다.
- 보통은 초기값을 주는 것이 더 안전하다.
주의❗ 빈 배열에서 초기값 없이 reduce() 를 호출하면 오류 발생
-> 리듀서 함수의 반환 값은 누산기에 할당되고, 누산기는 순회 중 유지되므로 결국 최종 결과는 하나의 값이 됩니다.
arr.reduce(callback[, initialValue])
reduce( )활용 예시
🔽중첩 배열 펼치기
const flattened = [[0, 1], [2, 3], [4, 5]].reduce(
function(accumulator, currentValue) {
return accumulator.concat(currentValue);
},
[]
);
// 펼친 결과: [0, 1, 2, 3, 4, 5]
//이어서 정리
'Frontend > JavaScript' 카테고리의 다른 글
[JavaScript] Promise와 async/await 차이점 (1) | 2022.09.01 |
---|---|
[JavaScript] JS언어의 특성 총정리 (0) | 2022.05.20 |
[Ajax | JSON] 서버-클라이언트 통신 이해하기 (0) | 2022.04.28 |
[JS/Python] 자바스크립트 기본 복습 + 활용 (0) | 2022.04.28 |
[JavaScript] return/ 스코프(scope) / 클로저(closure, 폐쇄) (0) | 2022.04.17 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- tilde caret
- getStaticPaths
- text input pattern
- 프리온보딩 프론트엔드 챌린지 3월
- 형제 요소 선택자
- 부트캠프항해
- 원티드 3월 프론트엔드 챌린지
- 항해99프론트
- D 플래그
- 항해99추천비추천
- float 레이아웃
- 원티드 프리온보딩 FE 챌린지
- 원티드 프리온보딩 프론트엔드 챌린지 3일차
- aspect-ratio
- nvm경로 오류
- nvm 설치순서
- 타입스크립트 장점
- grid flex
- is()
- fs모듈 넥스트
- reactAPI
- 원티드 FE 프리온보딩 챌린지
- 틸드와 캐럿
- 항해99프론트후기
- Prittier
- getServerSideProps
- 프리렌더링확인법
- ~ ^
- && 셸 명령어
- 타입스크립트 DT
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함