美文网首页
2018-08-22

2018-08-22

作者: 小付君 | 来源:发表于2018-08-22 21:47 被阅读0次

es6中数组的几种循环

对于数组循环,之前我们常用的方式就是:for,while等语法。但是在es6中我们可以尝试采用更多的循环方式进行数组的循环:

1.forEach

forEach方式用于数组的循环遍历,其参数只有两个,第一个参数是函数,第二个参数是指向的对象。

arr.forEach((item, index, arr)=>{

    console.log(item, index, arr)

})

以下几种方法的参数和forEach中的参数相同。

2.map

map也用来数组的遍历,但是其会返回一个新的数组。若map中有return,则会将数组中的元素进行加工后返回一个新的数组;若没有return,则可以将其当做forEach使用;

3.filter

filter过滤符合条件的数组元素,并将符合条件的所有元素返回给一个新的数组。即return true,则可以将当前的元素筛选进新的数组。

4.some

some方法用来判断数组中的元素中是否有满足要求的元素。若有,则返回true,否则返回false。

例如:arr.some((item, index, arr)=>{

    return item>200;

})

上述代码的意思是若arr中的元素有大于200的,则结果返回true。

find

find方法主要查找数组中是否存在满足条件的元素,与some方法的区别是,其返回值是查找到的第一个元素值。

return 条件

findIndex

与find方法类似,只是findIndex返回的是满足条件的元素的下标。

return 条件

includes

判断数组中是否存在某个元素,其不能用于条件查询。

arr.includes('apple');

返回结果为true或者false

5.every

every方法用来判断数组中的元素是否都满足条件,都满足才会返回true。

6.reduce

reduce方法用来求和,其第一个参数也是函数,但是函数的参数与之前的参数有些不同。

arr.reduce((pre, curr, index,  arr)=>{

    return pre+curr;

});

上面代码中pre为之前项的元素的和,index为当前元素的下标。

7.reduceRight

与reduce相同,只是reduceRight的计算方式是从右往左开始加。

8.for...of

for...of同样可以用于数组的循环。

for(let key of arr.keys()) {

    //遍历数组的下标

}

for(let val of arr) {

    //遍历数组的值

}

for(let [val, key] of arr.entries()) {

    //遍历数组的每一项的值和下标

}

相关文章

网友评论

      本文标题:2018-08-22

      本文链接:https://www.haomeiwen.com/subject/qyhuiftx.html