龙空技术网

JavaScript数组遍历的12种方法

架构摆渡 23

前言:

而今兄弟们对“js如何遍历数组的数据结构”大约比较关切,我们都想要分析一些“js如何遍历数组的数据结构”的相关内容。那么小编同时在网上网罗了一些关于“js如何遍历数组的数据结构””的相关资讯,希望朋友们能喜欢,大家快快来学习一下吧!

作为JavaScript开发人员,熟悉数组的遍历和操作是非常重要的。数组遍历是处理和操作数组元素的基本需求之一。JS数组遍历,基本就是for,forin,foreach,forof,map等等一些方法。

本文将介绍JavaScript中的12种常见数组遍历方法,帮助你成为数组操作的老司机。

第一种:for循环,也是最常见的

最简单的一种,也是使用频率最高的一种,虽然性能不弱,但仍有优化空间

const arr = [11, 22, 33, 44, 55, 66, 77, 88];for (let i = 0; i < arr.length; i++) {      console.log(arr[i]);    }
第二种:优化版for循环
const arr = [11, 22, 33, 44, 55, 66, 77, 88];let len = arr.lengthfor (let i = 0; i < len; i++) {      console.log(arr[i]);    }
第三种:forEach()

1.)forEach() 遍历普通数组

const arr = [11, 22, 33, 44, 55, 66, 77, 88];arr.forEach(item => {      //forEach循环      console.log(item);    });

2.)forEach() 遍历对象类型数组

const arrObj = [      {        id: 1,        name: "张三"      },      {        id: 2,        name: "李四"      },      {        id: 3,        name: "王五"      }    ];arrObj.forEach(item => {   console.log(item.id + "-------" + item.name);});
第四种:map()
 const arr = [11, 22, 33, 44, 55, 66, 77, 88]; var newArr = arr.map((value, index) => {      console.log(value + "----" + index);      return value * 10;    }); console.log(newArr);
第五种:filter遍历
let arr = [56, 15, 48, 3, 7];let newArr = arr.filter(function (value, index, array) {    return value % 2 === 0;});console.log(newArr)// [56, 48]
第六种:for…of 方法

作为ES6新增的循环方法,个人觉得相当好用,而且方便。这个方法避开了for-in循环的所有缺陷。而且,它可以正确响应break、continue和return语句。

//循环数组let arr = ['123','qwewq','sfds'];for(let item of arr){    console.log(item);    //item指的的就是数组每一项的值。不是索引。}//输出//'123'//'qwewq'//'sfds'
第七种:for…in 方法

for in循环是用来遍历对象的。要知道JavaScript对象的所有属性都是字符串,不过属性对应的值可以是任意数据类型。(注意:遍历时不仅能读取对象自身上面的成员属性,也能遍历出对象的原型属性)

let obj = {a:1, b:2, c:3};for (let prop in obj) {    //prop指对象的属性名console.log(prop, obj[prop]);}// 输出:// a,1// b,2// c,3
第八种:find方法
[1,4,-5,10].find((n) => n < 0 )//-5[1,5,10,15].find(function(value,index,arr){ return value > 9})//10//上面代码中,find方法的回调函数可以接受三个参数,依次为当前的值、当前的位置和原数组。
第九种:findIndex方法
//遍历数组找到第一个符合条件的项,并返回该项的索引值;不会继续遍历数组;否则返回-1。不会改变数组[1,5,10,15].findIndex(function(value,index,arr){ return value > 9})//2//findIndex() 当中的回调函数也是接收三个参数,与find() 相同。
第十种:Array.some() 方法
1)如果有一个元素满足条件,则表达式返回true,剩余的元素不会再执行检测。2)如果没有满足条件的元素,则返回false。3)返回值是布尔值 var ages = [3, 18, 17, 16] var checkoutVal = function checkout (age) {   console.log(age >= 18) // false true  有一个满足条件的会停止检测剩余的元素   return age >= 18 } console.log(ages.some(checkoutVal)) // truelet someArr = [2,3,4];let someResult = someArr.some((item, index)=>{  return item > 3});console.log(someResult);// 结果为: true
第十一种:Array.every() 方法 (所有的,每一个)
1)如果数组中有一个元素不满足,则整个表达式返回false;且剩余的元素不会再进行检测2)如果所有元素都满足条件,则返回true。3)返回值是布尔值  var ages = [3, 18, 17, 16]  const fn = (currentValue) => currentValue < 40  console.log(ages.every(fn)) // true  值全都符合函数条件    let everyArr = [2,3,4];let everyResult = everyArr.every((item, index)=>{  return item > 0});console.log(everyResult);// 结果为: true
第十二种:reduce() 方法
1)接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值。2)第二个参数作为第一次调用的a的值// reducerlet reduceArr = [0,1,2,3,4]let reduceResult = reduceArr.reduce((a, b)=>{  return a + b;});console.log(reduceResult);// 结果: 10

各种遍历方式的性能对比

上述列举了几种方式都有一一做过对比分析,基本上可以得出的结论是:

普通for循环才是最优雅的

(PS:以上所有的代码都只是进行空的循环,没有再循环内部执行代码,仅仅是分析各自循环的时间而已)

分析结果

以下截图中的数据是,在chrome (支持es6)中运行了100次后得出的结论(每次运行10次,一共10个循环,得到的分析结果)

标签: #js如何遍历数组的数据结构 #js如何遍历数组的数据结构格式 #js数组获取索引 #js循环遍历字符串 #js遍历数组对象