js中for和foreach区别 ,js for和foreach的哪个效率高

本文目录

js for和foreach的哪个效率高


forin 是遍历对象的 其实不适用遍历数组

js中for和foreach区别
,js for和foreach的哪个效率高图1

JS中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中for和foreach区别
,js for和foreach的哪个效率高图2

js中的map方法


forEach: 对数组中每一个元素都运行函数,该方法没有返回值。如果你想对数据里的每一个元素进行处理,可以采用forEach来替换 for循环
map:对数组中每一个元素都运行函数, 返回由每次函数执行的结果组成的数组。果你想对数据里的每一个元素进行处理,可以采用forEach来替换 for循环,和forEach不同的是,它最终会返回一个新的数组,数组的元素是每次处理先前数组中元素返回的结果
reduce: 对数组中的所有元素调用指定的回调函数。 该回调函数的返回值为累积结果,并且此返回值在下一次调用该回调函数时作为参数提供。

js中for和foreach区别
,js for和foreach的哪个效率高图3

如何形象地解释 Javascript 中 map


map,forEach,reduce是html5的Javascript数组中提供的新的API接口。
其中
1.map是遍历数组,通过回调函数中的计算返回一个和原数组项对应的结果,回调函数中需要return 如果不写则return undefined,新的数组无原数组的引用。
2. forEach是单纯的对数组进行遍历,和for类似,回调函数中对每一项的处理根据自己的意愿处理,没有返回值。即使回调中写return 结果也是undefined。
3. reduce 是对数组进行遍历,它第一个参数为回调函数a,回调函数a接受两个参数,第一个参数为当前结果(source),第二个参数为当前遍历的执行数据(item)。第二个参数为初始化值。一般用于递归操作。需要有返回值。

js中for和foreach区别
,js for和foreach的哪个效率高图4

以上就是关于js中for和foreach区别 ,js for和foreach的哪个效率高的全部内容,以及js中for和foreach区别 的相关内容,希望能够帮到您。

上一篇 2022年11月24日08时35分25秒
下一篇 2022年11月24日08时37分40秒

相关推荐

  • 语气表达有哪几种方式

    本文目录 1. 命令语气 2. 祈使语气 3. 陈述语气 4. 疑问语气 语气是指说话者表达情感、态度和意图的方式。在英语中,语气的表达方式有很多种,下面我们详细介绍几种常见的表达方式。 1. 命令语气 命令语气用于向别人下达命令或请求,通常以动词原形开头,语气强烈,常用于正式场合或紧急情况。例如: Sit down! (坐下!) Open the door, please. (请打开门。) Don't touch that! (别碰那个!) 2. 祈使语气 祈使语气用于表达请求、劝告或建议,语气比命令语气缓和。常用于日常交流中,表示请求或希望对方做某事。例如: Please be quiet…

    英语知识 2023年06月03日
    11
  • 指示代词前能加介词吗

    在学习英语语法的过程中,我们都知道指示代词可以用来指代特定的人或事物,例如:this,that,these,those等。但是,当我们需要在句子中使用介词时,是否可以在指示代词前加上介词呢? 答案是肯定的。在英语中,指示代词前是可以加上介词的,以便更好地表达句意。下面是一些常见的介词和它们与指示代词的搭配: with this:用这个 to that:对于那个 for these:为这些 from those:从那些 需要注意的是,在某些情况下,指示代词前不能加介词。例如,当指示代词作为主语或宾语时,我们不能在其前面加上介词,否则会使句子语法上不正确。下面是一些例子: This is my b…

    英语知识 2023年06月03日
    11
  • 现在进行时举例

    英语语法中,现在进行时是指正在发生的动作或状态。它由be动词(am/is/are)和动词-ing形式组成。下面是一些现在进行时的例子: 我正在写一篇文章。(I am writing an article.) 他们正在看电影。(They are watching a movie.) 她正在学习英语。(She is studying English.) 我们正在吃晚饭。(We are having dinner.) 她正在跳舞。(She is dancing.) 他们正在打篮球。(They are playing basketball.) 我们正在等待他们的到来。(We are waiting f…

    英语知识 2023年06月03日
    11
  • 主语从句是什么之一

    在英语语法中,主语从句是一个常见的语法结构。它是指在一个句子中,主语本身是一个从句。主语从句通常由一个连词引导,例如:“that”、“whether”或“if”。 主语从句的作用是在句子中充当主语,从而使句子更加丰富多彩。主语从句可以用来表达各种不同的意思,例如: What you said is true.(你说的是真的。) Whether we go or not doesn't matter.(我们去不去都无所谓。) If it rains tomorrow, we'll stay inside.(如果明天下雨,我们就呆在室内。) 在使用主语从句时,需要注意一些语法规则。例如,需要确保主…

    英语知识 2023年06月03日
    11
  • 初中被动语态的用法

    本文目录 1.什么是被动语态 2.被动语态的用法 3.被动语态的注意事项 4.总结 被动语态是英语语法中的一种重要形式,初中阶段的学生应该掌握被动语态的用法并能够正确运用。下面将介绍初中被动语态的用法。 什么是被动语态 被动语态是指句子的主语是动作的承受者,而非动作的执行者。被动语态的结构为“be + 过去分词”。 例如,句子“Tom writes a letter”(汤姆写了一封信)可以变为被动语态的句子“a letter is written by Tom”(一封信被汤姆写了)。 被动语态的用法 强调动作的承受者 被动语态常用于强调动作的承受者,使其成为句子的重点。 例如,句子“The c…

    英语知识 2023年06月03日
    11
  • 总之英语高级表达

    本文目录 1. 使用动词的不同形式 2. 运用复杂句子结构 3. 使用高级词汇和短语 英语作为全球通用语言,在现代社会中扮演着重要的角色。掌握英语高级表达可以帮助我们更好地表达自己,与人交流,提高工作效率。以下是一些英语高级表达的技巧和建议: 1. 使用动词的不同形式 英语动词有多种形式,如原形、过去式、分词等,使用不同形式可以丰富句子结构,增加语言表达的多样性。例如: I have been studying English for five years. (现在完成进行时) The book, written by a famous author, is very popular. (过去…

    英语知识 2023年06月03日
    11
  • 如何处理反对意见

    当我们在进行英语学习或者使用时,难免会遇到一些反对意见。这些反对意见可能来自于老师、同学或者其他人。那么我们应该如何处理这些反对意见呢? 首先,我们需要听取反对意见者的观点。不能仅仅因为自己的观点而否定别人的看法。听取反对意见者的观点,可以让我们更全面地了解问题,并有助于我们更好地掌握英语知识。 其次,我们需要认真思考反对意见的合理性。有些反对意见是有道理的,我们需要认真思考并且尝试理解。如果我们发现自己的观点确实存在问题,我们应该适时调整自己的看法。 最后,我们需要尊重反对意见者。无论对方的观点是否正确,我们都应该尊重他们的观点和看法。如果我们可以以一种尊重的方式与对方交流,我们就有更多的机…

    英语知识 2023年06月03日
    11
  • 什么叫反身代词

    反身代词是英语语法中的一个重要概念,它通常用来强调句子中的主语。反身代词是指在句子中作为宾语的代词,用于表示某个动作的执行者和承受者是同一个人或物。 英语中的反身代词有:myself, yourself, himself, herself, itself, ourselves, yourselves, themselves。这些代词的特点是它们都以“-self”或“-selves”结尾。 反身代词通常在句子中作为宾语出现,例如: I hurt myself while playing basketball. (我在打篮球时伤到了自己。) She bought herself a new dre…

    英语知识 2023年06月03日
    11