es6+ 数组语法规范(一): 数组遍历方式、方法

本文详细介绍了ES5和ES6中数组的遍历方式,包括for循环、forEach、map、filter、some、every和reduce。此外,还讨论了ES6引入的for...of迭代,并探讨了Array.from()、Array.of()、fill()、find()、findIndex()、copyWithin()、indexOf()、includes()以及ES10的flat()和flatMap()等方法的使用和特点。
摘要由CSDN通过智能技术生成

Array在 ES6 中新增了很多实用的原生 API,方便开发者对 Array 的操控性更强,如 for…of、from、of、fill、find、findIndex等。


一、ES5 中数组遍历方式

let arr = [1, 2, 3, 2, 4]

1.1 for循环

for (let i = 0; i < arr.length; i++) {
   
    console.log(arr[i])
}

后来语法有所升级,到 ES5 遍历数组的 API 多了起来,其中有 forEach、every、filter等,同样的功能可以用 forEach 、 map 、 every 等方法来实现。

1.2 forEach() 没有返回值,只是针对每个元素调用func

arr.forEach(function(elem, index, array) {
   
    if (elem === 2) {
   
        continue
    }
    console.log(elem, index)
})

这个语法看起来要简洁很多,不需要通过索引去访问数组项,然而它的缺点也是很明显,不支持 break、continue 等。

[1, 2, 3, 4, 5].forEach(function(e) {
   
    if (e === 2) {
   
        return;
    } else {
   
        console.log(e)
    }
})

这段代码的"本意"是从第一个元素开始遍历,遇到数组项 2 之后就结束遍历,不然打印出所遍历过的数值项。可是,事实让你大跌眼镜,因为它的输出是 1, 3, 4, 5。

注意

forEach 的代码块中不能使用 break、continue,它会抛出异常。

1.3 map() 返回新的数组,每个元素为调用func的结果

let result = arr.map(function(value) {
   
    value += 1
    return value
})
console.log(arr, result)				// [1, 2, 3, 2, 4]  [2, 3, 4, 3, 5]

1.4 filter() 返回符合func条件的元素数组

let result = arr.filter(function(value) {
   
    return value == 2
})
console.log(arr, result)				// [1, 2, 3, 2, 4] [2,2]

1.5 some() 返回boolean,判断是否有元素符合func条件

let result = arr.some(function(value) {
   
    return value == 4
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值