JS中map()与forEach()的区别和用法

Posted 手可摘星辰c

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS中map()与forEach()的区别和用法相关的知识,希望对你有一定的参考价值。

相同点:

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

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

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

4.只能遍历数组

 

不同点:

map()

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

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

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

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);})

以上是关于JS中map()与forEach()的区别和用法的主要内容,如果未能解决你的问题,请参考以下文章

map、foreach、reduce、filters的用法及区别

forEach用法与map用法区别

forEach用法与map用法区别

map和forEach的区别和用法

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

js中forEach的用法forEach如何跳出循环forEach与for之间的区别