数组方法map和forEach的使用方法

map和forEach的使用方法都是循环遍历数组中的每一项,每一次执行匿名函数都支持三个参数,数组中的当前项item,当前项的索引index,原始数组input。匿名函数中的this都是指window,只能遍历数组。

map() 方法按照原数组元素的顺序进行遍历处理,会返回一个新的数组,当map每次执行的方法有返回值即为新数组对应的元素的值,无返回值则新数组对应的元素值为undefined。map可以接收三个参数map(item, index, arr)分别为当前元素值、当前元素的索引和原数组对象。

forEach()用于调用数组的每个元素,并将元素传递给回调函数,返回undefined。实际上forEach就相当于一个for循环,forEach同样也是接收三个参数,跟map一样。对于空数组是不会执行回调函数的。

相同点:

一、都是循环遍历数组;

二、都接收三个参数:每一项、索引、原数组

三、执行匿名函数中的this指向window

不同点

map()会返回一个新数组,存在映射关系,不会对空数组进行检测;

forEach() 只是按顺序把数组中的元素传递给匿名函数使用,执行后返回undefine,会对空数组进行检测不会执行匿名函数。

filter只有在回调函数执行前传入的数组元素才有效,在回调函数开始执行后才添加的元素将被忽略,而在回调函数开始执行到最后一个元素这一期间,数组元素被删除或者被更改的,将以回调函数访问到该元素的时间为准,被删除的元素将被忽略。新的数组只包含满足条件的项。

那从性能方面如何去选择呢?

肯定是 for > forEach > map,map 会返回一个等长数组,forEach 不会,所以 forEach 大于 map。

你可能感兴趣的:(数组方法map和forEach的使用方法)