js数组循环的几个常用方法比较(for、forEach、map)

1、for循环是es5的常用数组循环方法,具体使用语法如下举例:

const arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
for (var i = 1; i < arr.length; i++) {
  console.log(i) // 打印的是1, 2, 3, 4, 5, 6
  if (i > 5) return
}

为什么打印的会是1 2 3 4 5 6呢?因为for循环中有return语句,该语句常用在函数中用来返回出一个结果,但是for循环中如果是用来return的话,可以中断循环。

2、forEach循环是es6方法,用来遍历数组的方法,具体举例如下:

const arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]    

arr.forEach((item, index, arr) => {
   console.log(item) //  打印 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
   if (item > 5) return
})

forEach遍历数组,其中有三个参数,item为数组的元素,index为元素对应的索引, arr即为数组本身,这里也使用了return语句,但是在forEach中使用return语句是不会中断循环的进行的。

3、map循环是es6方法,用来遍历数组的方法,具体举例如下:

const arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

const newArr = arr.map((item, index, arr) => {
    console.log(item) // 输出 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
    if (item < 5) {
        return item * 2
    }
    return item
})
console.log(newArr) // 输出 [2, 4, 6, 8, 5, 6, 7, 8, 9, 10]

map方法和forEach基本一样,有return语句也不会中断循环,唯一不同的是map有返回值,只要满足遍历的条件,就返回出来,组成一个新的数组。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>