Js数组遍历方法对比总结
引言:
ES6为javascript为数组遍历提供了新的一种方式: for....of....。那之前的遍历方法各存在哪些缺点?for...of...有什么好处?接下来,我们先回顾一下有多少种方式。
方法:
第一种: for 循环
data:image/s3,"s3://crabby-images/acf53/acf53ca47773a1bda163d63c5650e625b3810457" alt=""
特点:
1. 代码不够简洁
2.常用,性能比较好,数组较大时,也需要优化。
第二种: forEach
data:image/s3,"s3://crabby-images/5a54e/5a54e9d286f855a9bc357e68632a1bfd40d21d35" alt=""
特点:
代码比较简洁,但是没法中断停止整个循环,性能比for弱
第三种: for ....in...
data:image/s3,"s3://crabby-images/7b3a2/7b3a2027de4b5eb292dfd801c4a93309bdeac04e" alt=""
特点:
更常用于对象遍历,注意点输出的i 是一个字符串类型,非数值类型,要用,通常还得转换,效率也比较低
第四种:for...of... (es6新增)
data:image/s3,"s3://crabby-images/1d732/1d732ef3ac5f5ef166c434cafdbf103855cd9456" alt=""
特点:
1. 可以用break终止循环,continute跳出当前循环,继续后面的循环
2. 用keys()方法获得数值型索引。
4. 能遍历的对象有:数组,类数组对象,字符串,set和map结构等具有iterator接口的数据结构
第五种: filter
data:image/s3,"s3://crabby-images/35f2e/35f2e6d57f395de067f5a394c05d33c8eae1e600" alt=""
特点:
不会对空数组检测 ,不会改变原始数组
第六种:map
data:image/s3,"s3://crabby-images/dd27c/dd27ce9ef06bc9249528eab8926bb076b8d5c75d" alt=""
特点:支持return 返回值,实际使用效率比foreach还低
第七种:every
data:image/s3,"s3://crabby-images/3ed7d/3ed7d42a30ad312817d58a91a623171fcea51e95" alt=""
特点:
检测数组所有元素都符合条件返回true,否则返回false.
第八种: some
data:image/s3,"s3://crabby-images/3cda8/3cda889d3b1c3a4b50e4bff0131998d56a06e666" alt=""
特点:
检测数组只要有一个符合条件就返回true,剩下元素不会再继续执行,全部不符合返回false
第9种:reduce & reduceRight
data:image/s3,"s3://crabby-images/75d41/75d41f43f7f21bb3290f497eca0edb4d1474879d" alt=""
特点:
reduce ()接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值
reduceRigh() 跟reduce不一样的是 他是从右边到左边。
第10种: find() & findIndex()
data:image/s3,"s3://crabby-images/6dbaa/6dbaa6ec0e98f024c46d0dedb21e5affdb3095fe" alt=""
特点:
1.find() 返回数组中符合测试函数条件的第一个元素。否则返回undefined 。
2.findIndex() 返回数组中符合测试函数条件的第一个元素位置