forEach,map,filter的区别使用

最近面试的时候遇到面试官问我这个问题,当时我因为只用过这个最基本的forEach这个迭代方法,所以只能说出这个方法的大概,然而被问到参数的时候,因为习惯性只会用前两个参数,没想到还有第三个参数。下面经过我自己查阅资料以及总结之后,为大家带来这个三个迭代方法的区别与相同之处。

相同之处

forEach

最早知道这个方法的时候是使用Jquery的迭代方法Each,有兴趣的朋友可以去了解一下,基本的使用情况都是差不多的。首先举一个常用的例子。

   var array = [[1,2,3,4],[2,4,5,6]]

    array.forEach(function (item,i,arr) {
        console.log('item的值:'+item)  //第一次是[1,2,3,4] 第二次是[2,4,5,6]
        console.log('i的值:'+i)          //第一次是0   第二次是1
        console.log(arr)                 //都是指向这个数组arr
        console.log(item[i]);           //第一次是1  第二次是4
    })

item是每次遍历的子元素,i是下标,arr这个用的比较少,实际发现指向的就是当前遍历的数组array

Map

这个方法的使用跟forEach没有什么区别,而且参数都是一样的。

filter(过滤器)

这个也是跟forEach相同的参数。用法稍微有点区别。

不同之处

1、是否有返回值
forEach
 var arr = [[1,2,3,4],[2,4,5,6]]
 console.log(arr.forEach(function (item, i) {

        return item
    }));            

结果如下:
在这里插入图片描述

Map
  var arr = [[1,2,3,4],[2,4,5,6]]
  console.log(arr.map(function (item, i) {

        return item
    }));

结果如下:
在这里插入图片描述

filter
  var arr = [[1,2,3,4],[2,4,5,6]]
  console.log(arr.filter(function (item, i) {

        return item
    }));

结果如下:
在这里插入图片描述
可以从中看到forEach的返回值是undefined,而Mapfilter的返回值确实相同的。那么Mapfilter到底有什么不同之处呢?

由于filter的翻译是过滤器的意思,所以filter更多时候是用来筛选条件符合的元素。如下:

  var a = [1,2,3,4,5,6,7,8,9,10]
    console.log(a.map(function (item, i) {

        return item >5
    }));



    console.log(a.filter(function (item, i) {

        return item >5
    }));

分别输出的结果是
Map的输出结果
filter的输出结果
filter返回的是一个新的数组,而Map返回的是原来的数组。将原来的数组对于条件返回。

总结

forEach、Map、filter三个迭代方法都各有优势,如果不需要返回值,只需要操作的话,可以直接使用forEach,如果需要返回值的话,可以使用Map、filter方法,如果需要条件筛选的话,可以直接用filter。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值