首页技术js foreach js foreach会改变原数组吗

js foreach js foreach会改变原数组吗

编程之家2026-07-03820次浏览

大家好,如果您还对js foreach不太了解,没有关系,今天就由本站为大家分享js foreach的知识,包括js foreach会改变原数组吗的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

详解JS中常见的5 种 for 循环

for循环在平时开发中使用频率最高的,前后端数据交互时,常见的数据类型就是数组和对象,处理对象和数组时经常使用到 for遍历,因此需要彻底搞懂这 5种 for循环。它们分别为:

1、for

for循环是出现最早,也是应用最普遍的一个遍历,能够满足绝大多数的遍历。可以遍历数组、对象、字符串,示例:

2、for... in

for... in是在 ES5中新增的,以任意顺序迭代一个对象的除Symbol以外的可枚举属性,包括继承的可枚举属性。

3、for... of

for... of语句在可迭代对象(包括 Array、Map、Set、String、TypedArray、arguments对象等等)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。

4、for await...of

创建一个循环,该循环遍历异步可迭代对象以及同步可迭代对象,包括内置的 String、Array,类数组对象(arguments或 nodeList),TypedArray, Map, Set和用户定义的异步/同步迭代器。

它使用对象的每个不同属性的值调用要执行的语句来调用自定义迭代钩子。

类似于 await运算符一样,该语句只能在一个async function内部使用

5、forEach

forEach是ES5版本发布的,按升序为数组中含有效值的每一项执行一次回调函数,那些已删除或者未初始化的项将被跳过(例如在稀疏数组上),一般认为是普通for循环的加强版。

6、map

遍历时可以返回一个新数组,新数组的结果是原数组中每个元素都调用一次提供的函数后返回的值。

1、使用场景差异

for循环是最早最原始的循环遍历语句,for内部定义一个变量,按照条件进行循环遍历,通常是数组的长度,当超过长度时就停止循环,一般遍历的都是数组或类数组。

遍历对象时,由于对象没有长度,所以使用 Object.keys()获取对象的所有属性,以数组形式返回。

for/ in主要是用来遍历对象上的可枚举属性,包括原型对象上的属性,按任意顺序进行遍历,遍历对象时获取到的是属性的键值,遍历的是数组,数组的下标当做键值。

for/ of用于遍历可迭代对象的数据,包括 Array、Map、Set、String、TypedArray、arguments对象等等。

for await...of用于遍历异步可迭代对象,该语句只能在一个async function内部使用。

forEach是 for的加升级版,使用更简单,携带参数更多,但本质还是数组的循环,每个元素都执行一次回调,不会改变原数组。

map是给原数组每个元素都执行一次回调,返回一个新数组,不会改变原数组。

2、功能差异

forEach、map不支持跳出循环,其他不支持。

for await... of能够支持异步操作,其他的不支持。

对于纯对象的遍历, for... in枚举更方便。

对于数组遍历,如果不需要索引,可以直接使用 for...of获取值,还可支持 break或 return;如果还需要索引,使用 forEach更适合,但不支持 return。

如果是一个数组映射成另一个数组,使用 map最合适。

3、性能差异

在测试环境、测试数据条件一致的情况下,性能排序为:

for> for of> forEach> map> for in。

for因为没有额外的函数调用和上下文,所以性能是最快的。

for... of具有 iterator接口的数据结构,可以使用它来迭代成员,直接读取键值。

forEach是 for的语法糖,还有许多的参数和上下文,因此会慢一些。

map因为它返回的是一个等长的全新数组,数组创建和赋值产生的性能开销较大。

for...in性能最差,因为需要列举对象的所有属性,有转化过程,开销比较大。

在项目开发中,我们应该根据实际需求,去选择一个合适的 for遍历。以下是一些使用建议:

如果需要把数据映射成另外一个数组,如变成对应布尔值,推荐使用 map,不会修改原数组,使用语法简单。

数组遍历时,可以使用 for、forEach或 for...of。

遍历的是纯对象时,推荐使用 for... in。

如果是需要对迭代器遍历,推荐使用 for... of。

如果是在数组中筛选符合条件的数组,使用 fillter。

面试官问我 JS 中 foreach 能不能跳出循环

JS中 forEach不能跳出循环。

分析:

forEach的基本特性:forEach是 JavaScript数组的一个方法,用于遍历数组中的每一个元素,并对每个元素执行一次提供的函数。这个函数接收三个参数:当前元素、当前元素的索引、调用 forEach的数组本身。

无法跳出循环的原因:forEach的设计初衷是为每个数组元素执行一次指定的函数,并没有提供中断或跳出循环的机制。在 forEach的内部实现中(无论是标准的还是伪代码形式的),通常是通过一个普通的 for循环来遍历数组元素,并依次调用提供的函数。由于这个 for循环是封装在 forEach方法内部的,外部代码无法直接控制它的中断。

尝试跳出循环的方法:

抛出异常:虽然可以通过在函数内部抛出异常来中断 forEach的执行,但这并不是一种推荐的做法。因为异常通常用于处理错误情况,而不是用于控制流程。此外,使用 try-catch语句来捕获异常也会增加代码的复杂性和运行时的开销。

修改伪代码:虽然可以通过修改 forEach的伪代码来实现根据函数返回值跳出循环的功能,但这并不符合 JavaScript中 forEach的实际行为。在标准的 JavaScript环境中,forEach方法并不会根据函数的返回值来中断循环。

替代方案:

for循环:如果需要能够跳出循环的遍历方式,可以使用传统的 for循环。for循环提供了更灵活的控制机制,包括中断循环(使用 break语句)和跳过当前迭代(使用 continue语句)。

其他数组方法:根据具体的业务场景,还可以选择使用 JavaScript提供的其他数组方法,如 find()、findIndex()、map()、filter()、every()和 some()等。这些方法通常具有更明确的语义和用途,可以更有效地处理特定的业务逻辑。

forEach方法在 JavaScript中用于遍历数组并为每个元素执行一次指定的函数,但它不提供中断或跳出循环的机制。如果需要能够跳出循环的遍历方式,可以考虑使用传统的 for循环或其他数组方法。在选择使用哪种遍历方式时,应根据具体的业务场景和需求来决定。

JS之for循环

JS的 for循环主要包含如下几种: for(let i= 0; i< len; i++), for-in, for-of, for-each。

至于第一种 for循环,地球人都会,按下不表。难点在于 for-in, for-of, for-each直接有什么区别,看起来都差不多的样子。

一句话概述 for-in与 for-of: for-in遍历得到的是 key值,适用于对象的遍历, for-of得到的是 value值,适合数组的遍历。只要有 iterator接口的数据结构,都可以使用 for-of循环,包括: Array, Map, Set, String, arguments对象, Nodelist对象

获得的是属性值

获得的是对象的索引值

遍历的时候不要用这个!

当给数组的原型添加属性时,for in会遍历到原型链上的属性

这时候只要判断是不是本身所有的属性就行了

传入匿名的回调函数,匿名函数的参数为:当前项item,索引index(可省),当前数组array(可省)

for-of这个方法避开了for-in循环的所有缺陷

与forEach()不同的是,它可以正确响应break、continue和return语句

map遍历与foreach类似,支持使用return语句,支持return返回值

参考链接 link

好了,文章到这里就结束啦,如果本次分享的js foreach和js foreach会改变原数组吗问题对您有所帮助,还望关注下本站哦!

手机制作流程图app,流程图一键生成c语言switch判断成绩?c语言switch例题