📍 forEach와 map의 차이가 무엇일까! 항상 궁금했었는데 생각난 김에 정리해보기
(참고자료: https://velog.io/@nayeon/Array%EC%9D%98-map-filter-reduce-forEach-%EB%A9%94%EC%86%8C%EB%93%9C, https://medium.com/@JeffLombardJr/understanding-foreach-map-filter-and-find-in-javascript-f91da93b9f2c)
✔ forEach, map, filter, reduce 정리하기
-> 위의 모든 메소드는 모두 사본을 반환하며 원래의 배열은 바뀌지 않음!
let array1= ['a', 'b', 'c'];
array1.forEach(element => console.log(element));
//expected output:'a'
//expected output:'b'
//expected output:'c'
arr.forEach(callback(현재값 [,index [,array]])[, thisArg]
let newArr=arr.map(function callback (현재값 [, index [, array]] ) {
// return newArr를 위한 요소
}[,thisArg)
let numbers = [1, 4, 9]
let roots = numbers.map(function(num){
return Math.squrt(num)
})
//roots is now [1, 2, 3]
//numbers is still [1, 4, 9]
let newArray = arr.filter(callback(curr [,index [,array]]){
return //새로운 배열에 포함되기 위해 통과할 조건
}[,this Arg]
function isBigEnough(value){
return value>=10
}
let filtered = [12, 5, 8, 130, 44].filter(isBigEnough);
//filtered is [12, 130, 44]
arr.reduce(callback (누산기, 현재값 [, currentindex [, array]]){
//return 누적 결과의 결과 값
[, 초기값]}
[0,1,2,3,4].reduce(function(acc,cur){
return acc+cur
}); //return 10
// -> 화살표 함수로 작성
[0,1,2,3,4].reduce((prev,cur => prev+cur))
var flattended = [[0,1], [2,3], [4,5]]
function (acc,crr){
return acc.concat(crr)
},
[]);
//return [0,1,2,3,4,5]