JS中map()与forEach()的用法

相同点:javascript

1.都是循环遍历数组中的每一项java

2.每次执行匿名函数都支持三个参数,参数分别为item(当前每一项),index(索引值),arr(原数组)数组

3.匿名函数中的this都是指向window函数

4.只能遍历数组this

 

不一样点:spa

map()code

map方法返回一个新的数组,数组中的元素为原始数组调用函数处理后的值索引

也就是map()进行处理以后返回一个新的数组事件

⚠️注意:map()方法不会对空数组进行检测ip

map方法不会改变原始数组

var arr = [0,2,4,6,8];
var str = arr.map(function(item,index,arr){
console.log(this);    //Window
console.log(this);
console.log(item);
console.log('原数组arr:',arr);   // 会执行五次
return item/2;},this);console.log(str); //[0,1,2,3,4]

forEach

 

forEach方法用于调用数组的每一个元素,将元素传给回调函数

⚠️注意: forEach对于空数组是不会调用回调函数的 ,

没有返回一个新数组&没有返回值

应用场景:为一些相同的元素,绑定事件处理器!

不可链式调用 

var arr = [0,2,4,6,8]

var sum =0;

var str = arr.forEach(item,index.arr){sum+= item;console.log("sum的值为:",sum);})