目录

- [forEach](#1)
- [every](#2)
- [some](#3)
- [map](#4)
- [filter](#5)
- [reduce && reduceRight](#6)
- [indexOf](#7)
- [lastIndexOf](#8)

前言

ES6原生语法中提供了非常多好用的数组'遍历'方法给我们,让我们可以实现更多更强大的功能,下面让我们通过这篇文章好好学习下,该如何使用它们

代码线上测试地址:babel test

forEach

对数组的每个元素执行一次提供的函数。跳过空位元素

没有办法中止或者跳出 forEach() 循环,除了抛出一个异常。如果你需要这样,使用 forEach() 方法是错误的。

语法解析

arr.forEach((currentValue,index,array)=>{});
// currentValue 数组中正在处理的当前元素
// index 当前索引值
// array 正在处理的数组
// 返回值是undefined

例子则是非常简单的应用了

[1,2,3].forEach((currentValue,index,array)=>{
console.log(currentValue,index,array);
});

every

回调函数中,所有的都返回真,则返回真,有一个返回假,则返回假。
简而言之:“一假则假”

语法解析

arr.every((currentValue,index,array)=>{
// currentValue = 当前执行元素
// index = 当前索引值
// array = 执行的数组
})
返回值是true或者false

可别小看这个方法,我自己平时工作当中两个方面经常使用到

  1. 全选中使用
  2. 多个关系的搜索中使用

先看一个简单的例子

[12, 5, 8, 130, 44].every((item)=>{
return item >= 10
})
上面的意思:当数组中所有的元素的值都大于10的时候则返回true,否则返回false

全选伪代码示例

let allChecked = false;
const arr = [
{
id:"a",
name:"a",
checked:false
},
{
id:"b",
name:"b",
checked:false
}
]
allChecked = arr.every((item)=>{
return item.checked === true
})
// 实现起来就是这么简单,当所有的都选中了,allChecked 全选的变量就赋值true
// 这如果硬是用es5的语法去实现的话,还是比较麻烦的

some

回调函数中有一个返回真,则返回真
简言之:“一真则真”

语法解析

arr.some((currentValue,index,array)=>{
// currentValue = 当前执行元素
// index = 当前索引值
// array = 执行的数组
})
返回值是true或者false

代码展示

let bok = [2, 5, 8, 1, 4].some((item)=>{
return item>5
})
// bok = true
// 只要有一个数组大于5 则整体返回true

map

> 创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。

语法

arr.map((currentValue,index,array)=>{
// currentValue = 当前执行元素
// index = 当前索引值
// array = 执行的数组
}) // 返回一个新的数组

实例

let arr = [1,2,3,4];
const map = arr.map(x=>x*2);
//返回每一个处理过后的新数组 [2,4,6,8]

filter

> 返回一个新数组,其结果是改数组中的每个元素符合条件的结果

语法

arr.filter((currentValue,index,array)=>{
// currentValue = 当前执行元素
// index = 当前索引值
// array = 执行的数组
}) // 返回一个新的数组

顾名思义这个应该肯定是各类查询,筛选上面

实例

let arr = [{name:"abc"},{name:"bcd"},{name:"afc"}];

arr.filter((item)=>{
return item.name.includes('b');
});
// 筛选出名字字段中带有b的项

reduce && reduceRight

> reduce()方法在数组的每个成员上执行一个reducer函数(您提供的),生成一个输出值。

reduceRight是从右到左的相加(其它的同reduce是一样的,所以这里只讲reduce)

语法

无参数
arr.reduce((accumulator, currentValue,currentIndex,array)=>{
// accumulator第一项的值或者上一次叠加的结果值
// currentValue 当前项
// currentIndex 当前项索引
// array 数组本身
});
有参数
arr.reduce((accumulator, currentValue,currentIndex,array)=>{},参数);
参数 = accumulator 第一次运行时的初始值

实例1:计算数据总和

const arr = [1,2,3];
const num = arr.reduce((acc,cur,index)=>{
return acc + cur
});
// num = 6 const num1 = arr.reduce((acc,cur,index)=>{
return acc+cur
},10)
// num = 16

实例2:计算一个字符串中字母出现的次数

const str = 'aaabbcccdd';
str.split('').reduce((acc,cur)=>{
acc[cur] ? acc[cur]++ : acc[cur] = 1
},{});
解析:初始化的值是一个空对象
运行的时候,判断对象里面是不是有当前的字母,
如果没有的话则添加到对象中,并赋值为1
如果已经存在的话在++,这样就计算出一个字符串中字母出现的次数
同样可以利用这点进行数组去重 const arr = ['a','a','b','c']; const obj = arr.reduce((acc,cur)=>{
return acc[cur] ? acc[cur]++ : acc[cur] = 1
},{}) 最后通过obj.keys() 的方法获取到的数组就是去重之后的。

indexOf

> indexOf()方法返回在数组中可以找到给定元素的第一个索引,如果不存在,则返回-1。

var beasts = ['ant', 'bison', 'camel', 'duck', 'bison'];

console.log(beasts.indexOf('bison'));
// expected output: 1 // start from index 2
console.log(beasts.indexOf('bison', 2));
// expected output: 4 console.log(beasts.indexOf('giraffe'));
// expected output: -1

lastIndexOf

> lastIndexOf()方法返回给定元素在数组中找到的最后一个索引,如果该元素不存在,则返回-1。数组从fromIndex开始向后搜索。

var animals = ['Dodo', 'Tiger', 'Penguin', 'Dodo'];

console.log(animals.lastIndexOf('Dodo'));
// expected output: 3 console.log(animals.lastIndexOf('Tiger'));
// expected output: 1

小结

本篇文章主要讲述了ES6中数组新增的一些方法,以及如何使用。其实这些方法的实战场景还是非常多的,需要在实战中才能有更加深刻的体会

ES6 数组遍历方法的实战用法总结(forEach,every,some,map,filter,reduce,reduceRight,indexOf,lastIndexOf)的更多相关文章

  1. 关于 ES5 & ES6 数组遍历的方法

    ES5 数组遍历方法 1.for 循环 , , , , ] ; i < arr.length; i++) { console.log(arr[i]) } 2.forEach , , , , ] ...

  2. js数组遍历方法总结

    数组遍历方法 1.for循环 使用临时变量,将长度缓存起来,避免重复获取数组长度,当数组较大时优化效果才会比较明显. 1 2 3 for(j = 0,len=arr.length; j < le ...

  3. JS数组遍历方法

    常用数组遍历方法: 1.原始for循环 var a = [1,2,3]; for(var i=0;i<a.length;i++){ console.log(a[i]); //结果依次为1,2,3 ...

  4. JavaScript ES6 数组新方法 学习随笔

    JavaScript ES6 数组新方法 学习随笔 新建数组 var arr = [1, 2, 2, 3, 4] includes 方法 includes 查找数组有无该参数 有返回true var ...

  5. 浅谈6种JS数组遍历方法的区别

    本篇文章给大家介绍一下6种JS数组遍历方法:for.foreach.for in.for of.. each. ().each的区别.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. ...

  6. 数组遍历方法forEach 和 map 的区别

    数组遍历方法forEach 和 map 的区别:https://www.cnblogs.com/sticktong/p/7602783.html

  7. 数组的高阶方法map filter reduce的使用

    数组中常用的高阶方法: foreach    map    filter    reduce    some    every 在这些方法中都是对数组中每一个元素进行遍历操作,只有foreach是没有 ...

  8. Python map filter reduce enumerate zip 的用法

    map map(func, list) 把list中的数字,一个一个运用到func中,常和lambda一起用. nums = [1, 2, 3, 4, 5] [*map(lambda x: x**2, ...

  9. javascript(基础)_对数组的遍历方法总结(find, findIndex, forEach,)

    一.前言                                                                                                ...

随机推荐

  1. Python基础——6面向对象编程

    类和实例 类是抽象的模版,例如汽车:而实例则是拥有相同方法的类的实现,例如汽车里面有大众.宝马.奔驰等等,这些车都能在地面上跑,但是它们的具体数据可以不一样. calss Student(object ...

  2. Managing Large State in Apache Flink®: An Intro to Incremental Checkpointing

    January 23, 2018- Apache Flink, Flink Features Stefan Richter and Chris Ward Apache Flink was purpos ...

  3. spring boot +mybatis(通过properties配置) 集成

    注:日常学习记录贴,下面描述的有误解的话请指出,大家一同学习. 因为我公司现在用的是postgresql数据库,所以我也用postgresql进行测试 一.前言 1.Spring boot 会默认读取 ...

  4. PyInstaller安装使用方法

    PyInstaller可以把Python应用程序及其所有依赖项捆绑到一个包中.用户可以在不安装Python解释器或任何模块的情况下运行打包的应用程序.PyInstaller支持Python 2.7和P ...

  5. Auto Layout - BNR

    继续UIImageView - BNR篇. 通过Homepwner TARGETS -> General -> Deployment Info -> Devices中的iPhone改 ...

  6. Ubuntu安装mysql之后,编译找不到头文件

    解决Ubuntu安装mysql之后找不到mysql.h问题   安装: sudo apt-get install libmysqlclient-dev   编译: gcc test.c -o test ...

  7. 2018 C++ Teaching Assistant Summary

    期末考结束后就留校开始了科研,最近刚回家休息了两三天,整理了思绪,准备补上这一篇拖延了一个多月的助教小结. 早在一年多前我上栋哥这门课时,我就十分乐意给予同学帮助,无论是技术上的,还是说思想上的(也可 ...

  8. pyspider煎蛋无聊图爬取

    命令行pyspider,启动pyspider. web预览界面太小,解决方法:找到pyspider的安装路径下的debug.min.css,修改css代码: 将其中的iframe{border-wid ...

  9. PS对街拍女孩照片增加质感

    看到原图时,我的内心是抗拒的,灰蒙蒙毫无质感可言,手机app大概都拍得比这好看(捂脸笑哭). 大概是因为偏背光,光线暧昧不够强烈,且50 1.4这只镜头锐度还欠佳的缘故.所以平时3天修完图的我,这次拖 ...

  10. ASP.NET下MVC设计模式的实现

    [转载]MVC架构在Asp.net中的应用和实现 转载自:http://www.cnblogs.com/baiye7223725/archive/2007/06/07/775390.aspx 摘要:本 ...