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()) {
//遍历数组的每一项的值和下标
}