JS数组遍历的十二种方式

遍历有如下几种方式
数组方法
- map
- forEach
- filter
- find
- findIndex
- every
- some
- reduce
- reduceRight
其他方法
- for
- for in
- for of
数组方法
map
核心
- 创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。
- 不改变原数组
- 返回值是一个新的数组
let testArr = ['子项0','子项1','子项2'];
let resultArr = testArr.map((item, index) => {
return `处理·${item}`
});
console.log(resultArr);
// 结果: ["处理·子项0", "处理·子项1", "处理·子项2"]
缺陷
可以使用return,但是不能使用break和continue
forEach
核心
- 对数组的每个元素执行一次提供的函数。
- 总是返回undefined。
- 不改变原数组
let testArr = ['子项0','子项1','子项2'];
testArr.forEach((item, index)=>{
return `forEach处理${item}`
});
缺陷
可以使用return,但是不能使用break和continue
filter
核心
- 对数组的每一项都进行过滤,返回符合条件的item组成的数组
- 不会改变原数组
let filterArr = ['子项0','子项1','子项2'];
let filterResult = filterArr.filter((item, index) => {
return item === '子项0';
});
console.log(filterArr); // ["子项0", "子项1", "子项2"]
console.log(filterResult); ["子项0"]
缺陷
可以使用return,但是不能使用break和continue
find
核心
- 遍历数组,找到第一个符合条件的项,并返回该项。否则返回undefined
- 不会改变数组
let findArr = ['子项0','子项1','子项2']
let findResult = findArr.find((item, index) => {
return item === '子项0';
});
console.log(findResult);
// 结果为: 子项0
缺陷
可以使用return,但是不能使用break和continue
findIndex
核心
- 遍历数组找到第一个符合条件的项,并返回该项的索引值。否则返回-1。
- 不会改变数组对象。
let findIndexArr = ['子项0','子项1','子项2'];
let findIndexResult = findIndexArr.findIndex((item, index)=>{
return item === '子项0';
});
console.log(findIndexResult);
// 结果为: true
缺陷
可以使用return,但是不能使用break和continue
every
核心
- 对数组中的每一项运行给定函数,如果该函数对每一项返回true,则返回true。简单说就是看数组的每个元素是否符合要求,都符合则返回true,否则返回false
let everyArr = [2,3,4];
let everyResult = everyArr.every((item, index)=>{
return item > 0
});
console.log(everyResult);
// 结果为: true
缺陷
可以使用return,但是不能使用break和continue
some
是对数组中每一项运行指定函数,如果该函数对任一项返回true,则返回true。
let someArr = [2,3,4];
let someResult = someArr.some((item, index)=>{
return item > 3
});
console.log(someResult);
// 结果为: true
缺陷
可以使用return,但是不能使用break和continue
reduce
- 接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值。
- 第二个参数作为第一次调用的a的值
// reducer
let reduceArr = [0,1,2,3,4]
let reduceResult = reduceArr.reduce((a, b)=>{
return a + b;
});
console.log(reduceResult);
// 结果: 10
缺陷
可以使用return,但是不能使用break和continue
reduceRight
- 和reduce一样是累加器,不过是从右往左计算
- 第二个参数作为第一次调用的a的值
let reduceRightArr = [0,1,2,3,4]
let reduceRightResult = reduceRightArr.reduceRight((a, b)=>{
return a + b;
});
console.log(reduceRightResult);
// 结果: 10
缺陷
可以使用return,但是不能使用break和continue
其他方法
for循环
核心
使用临时变量,并且遍历的是key.
let testArr = ['子项0','子项1','子项2'];
for(var i = 0; a < testArr.length; i++){
console.log(testArr[i]);
}
缺陷
- 可以正常使用使用break和continue, 但是不能正常使用return
let testArr = ['子项0','子项1','子项2'];
// break
for(var i = 0; i < testArr.length; i++) {
if(i === 1) {
break;
}
console.log(testArr[i]);
}
// 结果为: 子项0 // continue
for(var i = 0; i < testArr.length; i++) {
if(i === 1) {
continue;
}
console.log(testArr[i]);
}
// 结果为: 子项0 子项目2 //return
for(var i = 0; i < testArr.length; i++) {
if(i === 1) {
return;
}
console.log(testArr[i]);
}
// 结果为什么也没有
for in循环
核心
遍历的是key
let testArr = ['子项0','子项1','子项2'];
for(let i in testArr){
console.log(testArr[i])
}
缺陷
- 可以正常使用使用break和continue, 但是不能正常使用return
let testArr = ['子项0','子项1','子项2'];
// break
for(let i in testArr){
if(i === 1) {
break;
}
console.log(testArr[i]);
}
// 结果为: 子项0 // continue
for(let i in testArr){
if(i === 1) {
continue;
}
console.log(testArr[i]);
}
// 结果为: 子项0 子项目2 //return
for(let i in testArr){
if(i === 1) {
return;
}
console.log(testArr[i]);
}
// 结果为什么也没有
for of循环
核心
遍历的是value
let testArr = ['子项0','子项1','子项2'];
for(let i of testArr) {
console.log(i);
}
缺陷
- 可以正常使用使用break和continue, 但是不能正常使用return
let testArr = ['子项0','子项1','子项2'];
// break
for(let value of testArr){
if(value === '子项1'){
break;
}
console.log(value);
}
// 结果为: 子项0 // continue
for(let value of testArr){
if(value === '子项1'){
continue;
}
console.log(value);
}
// 结果为: 子项0 子项目2 //return
for(let value of testArr){
if(value === '子项1'){
return;
}
console.log(value);
}
// 结果为什么也没有
注意️
- 数组方法都不可以用break和continue,for循环之类的不可以用return但是可以正常使用break和continue
JS数组遍历的十二种方式的更多相关文章
- js 数组去重常见的几种方式
1.利用标记 var arr = [2,6,2,6,4,3,16];// arr = [2,6,4,3,16] function norepeat(arr){ var res = []; for(va ...
- 【js】js数组置空的三种方式
方式1: var arr = new Array(1,2,3); alert(arr); arr.splice(0, arr.length); alert(arr); 方式2: var arr = n ...
- 浅谈6种JS数组遍历方法的区别
本篇文章给大家介绍一下6种JS数组遍历方法:for.foreach.for in.for of.. each. ().each的区别.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. ...
- JavaScript学习12 JS中定义对象的几种方式
JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...
- JavaScript学习12 JS中定义对象的几种方式【转】
avaScript学习12 JS中定义对象的几种方式 转自: http://www.cnblogs.com/mengdd/p/3697255.html JavaScript中没有类的概念,只有对象. ...
- 转→js数组遍历 千万不要使用for...in...
看到一篇内容还不错,但是排版实在糟糕, 逼死强迫症患者啊,直接拉下去找原文连接,找到了,但是已经消失了···500错误... 第一次因为实在看不下去一篇博客的排版, 为了排版而转载... 转载地址:h ...
- java遍历Map的几种方式
1.遍历map的几种方式:private Hashtable<String, String> emails = new Hashtable<String, String>(); ...
- JS弹出对话框的三种方式
JS弹出对话框的三种方式 我们用到了alert()方法.prompt()方法.prompt()方法,都是在网页有一个弹出框,那么就让我们探究一下他们之间的区别: 一.第一种:alert()方法 < ...
- java 遍历Map的四种方式
java 遍历Map的四种方式 CreationTime--2018年7月16日16点15分 Author:Marydon 一.迭代key&value 第一种方式:迭代entrySet 1 ...
随机推荐
- Typora+PicGo-Core(command line)+SMMS、github、gitee实现Typora图片上传到图床
Typora+PicGo-Core(command line)+SMMS.github.gitee实现Typora图片上传到图床 1 安装插件2 配置config.json 2.1 设置SMMS ...
- Oracle数据库迁移至PostgreSQL数据库问题及解决
Oracle数据库迁移PostgreSQL数据库问题及解决 目录 如何计划迁移数据库(现状及问题分析) 统计系统表及表功能 解耦公共表 建立数据库 迁移表结构 导入表数据 改SQL语法 保证数据时效性 ...
- windows:根据特征码查找内核任意函数
在windows平台做逆向.外挂等,经常需要调用很多未导出的内核函数,怎么方便.快速查找了?可以先用IDA等工具查看硬编码,再根据硬编码定位到需要调用的函数.整个思路大致如下: 1.先查找目标模块 ...
- OKHttp 官方文档【二】
OkHttp 是这几年比较流行的 Http 客户端实现方案,其支持HTTP/2.支持同一Host 连接池复用.支持Http缓存.支持自动重定向 等等,有太多的优点. 一直想找时间了解一下 OkHttp ...
- Netty(一):server启动流程解析
netty作为一个被广泛应用的通信框架,有必要我们多了解一点. 实际上netty的几个重要的技术亮点: 1. reactor的线程模型; 2. 安全有效的nio非阻塞io模型应用; 3. pipeli ...
- 关于Exceptionless日志收集框架如何关闭磁盘缓存
问题:在使用Exceptionless的时候,Exception在收集到日志时会默认在appdata里面缓存当条日志的缓存文件,时间久了之后,如果收集到的日志越多磁盘的空间就会不足. 我使用的环境是 ...
- Java 的几种运算符
一.原码.反码.补码 1 用二进制表示 00000001 -1 如果只变符号位(原码) 10000001 那么 1 + -1 = 10000010 = -2 -1 的反码 11111110 除去符号位 ...
- CSS变化、过渡与动画
CSS变换用于在空间中移动物体,而CSS过渡和CSS关键帧动画用于控制元素随时间推移的变化. 变换.过渡和关键帧动画的规范仍然在制定中.尽管如此,其中大多数特性已经在常用浏览器中实现了. 1.二维变换 ...
- 极简 Node.js 入门 - 1.4 NPM & package.json
极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...
- MySQL回表查询
一.MySQL索引类型 1.普通索引:最基本的索引,没有任何限制 2.唯一索引(unique index):索引列的值必须唯一,但是允许为空 3.主键索引:特殊的唯一索引,但是不允许为空,一般在建表的 ...