ES5中数组遍历方式:
for循环
forEach():没有返回值,只是针对每个元素调用func
map():返回新的Array,每个元素为调用func的结果
filter():返回符合func条件的元素数组
some():返回boolean,判断是否有元素、是否符合func条件
every():返回boolean,判断每个元素是否符合func条件
reduce():接收一个函数作为累加器
for in ???
 
先定义数组arr提供下面代码使用:
let arr = [1, 2, 3];

 

for循环:

for (let i = 0; i < arr.length; i++) {
console.log(arr[i]);
}

  

forEach():

forEach有三个参数:当前元素,当前索引值,数组本身

arr.forEach((item, index, array) => {
console.log(item, index, array);
});

  

for和forEach之间的区别是什么
for是可以跳出循环,而forEach是不能够跳出循环
也就是forEach不能使用break和continue两个关键字。
 
map:
从下面方法可以看出,map返回的是新数组,不会影响原来数组,没有副作用
let result = arr.map((value) => {
value++;
return value;
});
console.log(arr, result);

  

filter:
从下面方法可以看出,filter返回的是新数组,不会影响原来数组,没有副作用
let farr = [1, 2, 3];
let fresult = farr.filter((value) => {
return value === 2;
});
console.log(farr, fresult);

  

some:
some只要找到一个符合条件的元素,就会返回true
let sresult = arr.some((value) => {
return value === 2;
})
console.log(arr, sresult);

  

every:
every只要有一个不符合条件的元素,就会返回false
let eresult = arr.every((value) => {
return value === 2;
})
console.log(arr, eresult);

  

reduce:
reduce第一个参数是方法,第二个参数是累加的初始值
第一个参数方法能有四个参数:
prev:上一次调用回调函数的值,第一次就是初始值
cur:当前处理元素的值
index:当前处理元素的索引值
array:原数组
 
下面使用reduce计算arr数组里面所有元素的累加值:
let sum = arr.reduce((prev, cur, index, array) => {
// 上一次处理的结果加上当前元素值
return prev + cur
}, 0)
console.log(sum, arr);

  

利用reduce找出数组里面最大的值:
let max = arr.reduce((prev, cur) => {
return Math.max(prev, cur)
}, arr[0])
console.log(max);

  

利用reduce实现数组去重:
let arr2 = [1, 2, 2, 3, 4, 1]
let dresult = arr2.reduce((prev, cur) => {
// 当cur不在prev的时候,prev增加一项cur
prev.indexOf(cur) == -1 && prev.push(cur)
return prev
}, [])
console.log(dresult);

  

for in:
Array.prototype.foo = function () {
console.log('foo');
}
for (let index in arr) {
console.log(index, arr[index])
}
上面代码先在Array数组对象增加一个原型方法foo。
下面调用for in 的时候会把这个新增的原型方法打印出来。
for in 在操作数组的时候不够纯粹,不建议使用for in来操作数组。
 

ES6中数组遍历方式:
find():返回第一个通过测试的元素
findIndex():返回的值为该通过第一个元素的索引
for of
values()
keys()
entries()
 
find():
let f1 = arr.find((value) => {
return value < 2
})
console.log(f1, arr);

  

findIndex():
let f2 = arr.findIndex((value) => {
return value < 2
})
console.log(f2, arr);

  

for of:
for (let item of arr) {
console.log(item);
}

  

values:
for (let item of arr.values()) {
console.log(item);
}

  这里跟for of效果一样

keys:
for (let item of arr.keys()) {
console.log(item);
}

  

entries:
既要获取到索引又要获取到内容
for (let [index, item] of arr.entries()) {
console.log(index, item);
}

  

ES6-11学习笔记--数组遍历的更多相关文章

  1. C++11 学习笔记 std::function和bind绑定器

    C++11 学习笔记 std::function和bind绑定器 一.std::function C++中的可调用对象虽然具有比较统一操作形式(除了类成员指针之外,都是后面加括号进行调用),但定义方法 ...

  2. PHP学习之中数组-遍历一维数组【2】

    在PHP学习之中数组[1]中学会怎么创建一个数组,如果PHP学习之中数组[1]中的元素多的话,我们访问元素又是一个问题了,下面我们就使用for语句while,foreach来遍历我们的数组: < ...

  3. JavaScript学习笔记-数组

    数组 数组中的每个元素的位置是索引,索引是基于32位的由0开始的数值,最大索引为(2的32次方-2),最大长度为(2的32次方-3) 数组是无类型的:元素可为任意类型:动态的:可根据需要自动增长.缩减 ...

  4. JavaScript学习笔记-数组(1)

    数组是值的有序集合.每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引.JavaScript数组是无类型的:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有不同的类型.数 ...

  5. Java菜鸟学习笔记--数组篇(三):二维数组

    定义 //1.二维数组的定义 //2.二维数组的内存空间 //3.不规则数组 package me.array; public class Array2Demo{ public static void ...

  6. JavaSE中Collection集合框架学习笔记(3)——遍历对象的Iterator和收集对象后的排序

    前言:暑期应该开始了,因为小区对面的小学这两天早上都没有像以往那样一到七八点钟就人声喧闹.车水马龙. 前两篇文章介绍了Collection框架的主要接口和常用类,例如List.Set.Queue,和A ...

  7. java学习笔记 --- 数组

    一.Java的内存分配   A:栈内存: 存储局部变量,只要是在方法中定义的变量都是局部变量.一旦变量的生命周期结束该变量就被释放.   B:堆内存: 存储所有new出来的,及实体(对象),每一个实体 ...

  8. ES6-11学习笔记--数组的扩展

    类数组 / 伪数组 Array.from() Array.of() copyWithin() fill() includes()   类数组.伪数组例子: let divs = document.ge ...

  9. JavaScript(ES6)学习笔记-Set和Map与数组和对象的比较(二)

    一.Map,Set,Array对比: 1.增 let map = new Map(); let set = new Set(); let array = []; map.set('t',1); //M ...

随机推荐

  1. JZ-049-把字符串转换成整数

    把字符串转换成整数 题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0 输入描述: 输入一个字符串,包括数字字母符号,可以为空 返 ...

  2. springCould注解和配置以及pom依赖

    SpringCloud注解和配置以及pom依赖说明 在本文中说明了pom依赖可以支持什么功能,以及支持什么注解,引入该依赖可以在application.properties中添加什么配置. 1.Spr ...

  3. Sequelize关联查询,where影响全局的解决

    需求背景 系统字段关联公司字段表,通过查询所有的系统字段然后关联查询指定的公司对应的字段. 问题代码 const sysField = ctx.model.SysDictionary; const c ...

  4. Java有了synchronized,为什么还要提供Lock

    摘要:在Java中提供了synchronized关键字来保证只有一个线程能够访问同步代码块.既然已经提供了synchronized关键字,那为何在Java的SDK包中,还会提供Lock接口呢? 本文分 ...

  5. 浏览器中 Http缓存

    分类: web缓存主要有:数据库缓存.服务器缓存(代理服务器缓存.CDN缓存),浏览器缓存. 数据库缓存 当web应用的关系比较复杂,数据库中的表很多的时候,如果频繁进行数据库查询,很容易导致数据库不 ...

  6. 微信小程序结合原生JS实现电商模板(二)

    接 <微信小程序结合原生JS实现电商模板(一)>,在首页列表加入购物车到购物和模块增删数量,动态计算商品价格实现后,本次提交主要实现了商品详情(还不完善)简单页面,从商品详情页跳转到购物车 ...

  7. np.vectorize()和crosstab()和pivotTab()函数解释

    numpy.vectorize(pyfunc, otypes=None, doc=None, excluded=None, cache=False, signature=None) Parameter ...

  8. Maven——setting.xml配置

    <settings> <localRepository>C:\Users\gcl\.m2\repository</localRepository> <serv ...

  9. # Redhat7 安装 yum源

    第一步:先卸载原来的yum rpm -qa |grep yum 查看原来是否安装 yum-3.4.3-118.el7.noarch yum-utils-1.1.31-24.el7.noarch yum ...

  10. [应用软件] VMware Workstation 12.0.0 Pro 正式版下载【附注册机+注册码】

    软件信息 软件名称: VMware Workstation 软件版本: 12 软件大小: 300 MB 软件语言: 简体中文 更新时间: - 软件授权: 免费 软件类别: 安装版 运行环境: WinX ...