js中对数组进行遍历都有哪些方法_js遍历json对象

js中对数组进行遍历都有哪些方法_js遍历json对象遍历有如下几种方式数组方法mapforEachfilterfindfindIndexeverysomereducereduceRight其他方法forforinforof数组方法map核心创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。不改变原数组返回值是一个新的数组lettestArr=[‘子项0′,’子项1′,’子项2’];letresultArr=t…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

c1a9acfe997cb2481b4c3a484475f62e.png

遍历有如下几种方式

数组方法

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 intestArr){

console.log(testArr[i])

}

缺陷

可以正常使用使用break和continue, 但是不能正常使用return

let testArr = [‘子项0′,’子项1′,’子项2’];//break

for(let i intestArr){if(i === 1) {break;

}

console.log(testArr[i]);

}//结果为: 子项0

//continue

for(let i intestArr){if(i === 1) {continue;

}

console.log(testArr[i]);

}//结果为: 子项0 子项目2

//return

for(let i intestArr){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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179411.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月21日 下午5:36
下一篇 2022年10月21日 下午5:46


相关推荐

  • 十进制转换成八进制(C++)

    十进制转换成八进制(C++)Description 用递归算法 把任一给定的十进制正整数转换成八进制数输出 Input 输入一个正整数 表示需要转换的十进制数 Output 输出一个正整数 表示转换之后的八进制的数 SampleInput1 方法 1 乱搞这种做法很有技术含量代码 include bits stdc h usingnamesp bits

    2025年11月25日
    5
  • openclaw(小龙虾🦞)

    openclaw(小龙虾🦞)

    2026年3月12日
    2
  • 浅谈Linux操作系统基础知识

    浅谈Linux操作系统基础知识Linux 操作系统认知 1 1 操作系统 英文名简称为 OS 定义 操作系统是用户与计算机硬件之间的界面 是控制 管理计算机系统内各种硬件和软件资源 有效地组织多种程序运行的程序集合 从下面插图可以看出操作系统是第一层软件 凌驾于软件和硬件之间 是其他平台运行的基础 控制管理系统资源 以便用户使用 2 操作系统功能 1 是控制和管理计算机硬件和软件资源的计算机程序 2 最重要的系统环境 3 管理各种其他的软件和程序的运行 4 对系统中文件进行管理 3 操作系统分类 1 桌面操作系统 主要

    2026年3月17日
    2
  • python多行注释快捷键mac_PyCharm for Mac快捷键小记

    python多行注释快捷键mac_PyCharm for Mac快捷键小记1 前言总结一下自己平时常用的 PyCharmforMa 快捷键 因为网上经常找到的都是 Windows 版本 所以当是备忘也好 后续会不定期更新 2 PyCharmforMa 快捷键快捷键说明 cmd b 跳转到声明处 cmd 加鼠标 cmd d 在下一行复制本行的内容 cmd 光标之前 后的位置 cmd opt 函数和方法前后的位置 cmd backspace 删除当前行 cmd

    2026年3月19日
    3
  • 罗技键盘怎么连台式电脑_罗技键盘蓝牙搜不到

    罗技键盘怎么连台式电脑_罗技键盘蓝牙搜不到罗技蓝牙键盘连接电脑需装入电池,打开电源开关,转动拨盘至【1】位置,然后长按【PC】键3秒进入【搜索】模式。打开电脑,前往【设置】-【设备】-【蓝牙和其他设备】,打开【蓝牙】,在蓝牙搜索列表中选中罗技蓝牙键盘的名称,确认配对即可完成连接。本文以惠普光影精灵6MAX,MacbookPro(分别连接K835有线键盘和K480蓝牙键盘);Windows10,macOSCatalina10.15.7…

    2022年10月16日
    4
  • JavaScript判断数组中是否包含某个值「建议收藏」

    JavaScript判断数组中是否包含某个值「建议收藏」有下面几种方法可以实现:方法一:array.indexOf判断数组中是否存在某个值,如果存在,则返回数组元素的下标,否则返回-1。letarr=[1,2,3,4];letindex=arr.indexOf(3);console.log(index);方法二:array.includes(searcElement[,fromIndex])此方法判断数组中是否存在某个值,如果存在返回true,否则返回falseletarr=[1,2,3,4];if(arr.includes(3))

    2022年10月7日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号