map、foreach、reduce、filter闭包的理解
forEach的含义和理解
MDN中对forEach的定义:forEach() 方法对数组的每个元素执行一次提供的函数。
注意: 没有返回一个新数组! & 没有返回值!
应用场景:为一些相同的元素,绑定事件处理器!
array.forEach(callback(currentValue, index, array){
//do something
}, this)
callback为数组中每个元素执行的函数,该函数接收三个参数:
currentValue(当前值):数组中正在处理的当前元素。
index(索引):数组中正在处理的当前元素的索引。
array:forEach()方法正在操作的数组。
假设我们有个数组,每个元素是一个人,你面前站了一排人。
foreach 就是你按顺序一个一个跟他们说做点什么,具体做什么
var arr = [1,2,3]
arr.forEach(function(item,index){console.log(item,index,arr)})
1 0 [1, 2, 3]
2 1 [1, 2, 3]
3 2 [1, 2, 3]
Map的含义和理解
MDN中对Map的定义map() 方法创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。
注意: 返回的是一个新数组,每个元素都是回调函数的结果。
let new_array = arr.map(function callback(currentValue, index, array) {
// Return element for new_array
}[, thisArg])
callback为数组中每个元素执行的函数,该函数接收三个参数:
currentValue(当前值):数组中正在处理的当前元素。
index(索引):数组中正在处理的当前元素的索引。
array:forEach()方法正在操作的数组。
thisArg:可选的。执行 callback 函数时 使用的this 值。
var arr = [1,2,3]
arr.map(e){e*2}
[2, 4, 6]
reduce的含义和理解
MDN中对reduce的定义:reduce() 方法对累加器和数组中的每个元素(从左到右)应用一个函数,将其减少为单个值。
reduce为数组中的每一个元素依次执行callback函数,不包括数组中被删除或从未被赋值的
回调函数第一次执行时,accumulator 和currentValue的取值有两种情况:调用reduce时提供initialValue,accumulator取值为initialValue,currentValue取数组中的第一个值;没有提供 initialValue,accumulator取数组中的第一个值,currentValue取数组中的第二个值。
注意:如果没有提供initialValue,reduce 会从索引1的地方开始执行 callback 方法,跳过第一个索引。如果提供initialValue,从索引0开始。
如果数组为空且没有提供initialValue,会抛出TypeError 。如果数组仅有一个元素(无论位置如何)并且没有提供initialValue, 或者有提供initialValue但是数组为空,那么此唯一值将被返回并且callback不会被执行。
arr.reduce(callback[, initialValue])
callback为执行数组中每个值的函数,包含四个参数:
accumulator:累加器累加回调的返回值; 它是上一次调用回调时返回的累积值,或initialValue(如下所示)。
currentValue:数组中正在处理的元素。
currentIndex 可选:数组中正在处理的当前元素的索引。 如果提供了initialValue,则索引号为0,否则为索引为1。
array 可选:可选的。调用reduce的数组
initialValue 可选:用作第一个调用 callback的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。 在没有初始值的空数组上调用 reduce 将报错。
[0, 1, 2, 3, 4].reduce(function(accumulator, currentValue, currentIndex, array){
return accumulator + currentValue;
});
callback accumulator currentValue currentIndex array return value
first call 0 1 1 [0, 1, 2, 3, 4] 1
second call 1 2 2 [0, 1, 2, 3, 4] 3
third call 3 3 3 [0, 1, 2, 3, 4] 6
foiurth call 6 4 4 [0, 1, 2, 3, 4] 10
说白了第一个参数就是前一次处理后的值,默认是第一个,第二个为当前处理的值,函数就是处理前一个与后一个结果再与下一个,最后为一层层处理后的值
var arr = [1,2,3,4,5]
arr.reduce((acc,cur)=>acc*cur)
120
filter的含义和理解
MDN中对filter的定义filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。
注意: 返回的是一个新的通过测试的元素的集合的数组
var new_array = arr.filter(callback[, thisArg])
callback用来测试数组的每个元素的函数。调用时使用参数 (element, index, array)。分别为
元素的值,元素的索引, 被遍历的数组
返回true表示保留该元素(通过测试),false则不保留。
thisArg:可选的。执行 callback 函数时 使用的this 值。
说白了就是过滤一个数u组,通过回调函数所有返回true的值为集合,创建一个新数组.
filter 不会改变原数组,它返回过滤后的新数组。
var arr = [1,2,3,4,5]
arr.filter(e=>e>2)
[3, 4, 5]