导航:首页 > 编程语言 > js迭代

js迭代

发布时间:2025-03-29 05:10:30

『壹』 js迭代和遍历有什么区别

迭代 iteration

在编程中,迭代是一种循环处理一组数据的过程。通常,迭代涉及到访问一个集合中的元素,这可以通过对数组使用循环实现,比如在JavaScript中使用for循环遍历数组元素。迭代的核心在于按顺序访问每个元素,直到遍历完集合。

迭代的核心工具是迭代器,它允许在不同类型的集合上执行循环操作,而不仅仅局限于数组。迭代器在现代JavaScript中以ES6引入的`iterator`接口为标志。这意味着,无论是链表、集合还是其他非数组类型的容器,只要实现`iterator`接口,都可以被迭代。

迭代器提供的便利性在于它简化了访问和处理集合元素的逻辑,使得编写代码更加灵活和易于理解。

迭代 iteration

至于遍历 traversal,这是一个更广泛的概念,不仅仅局限于编程领域。在数据结构和算法中,遍历通常指访问数据结构(如树、图或集合)中的每个节点或元素。在JavaScript中,遍历可以指的是访问DOM元素,或者访问非数组数据结构中的元素。

树遍历 tree traversal

在涉及到树结构的数据时,遍历指的是按照一定的顺序访问树中的每个节点。常见的树遍历方式包括前序遍历、中序遍历和后序遍历。在DOM树中,遍历通常指从根节点开始,按照某种顺序遍历所有子节点。

总结,迭代侧重于对数据集合的顺序访问,而遍历则是一个更广泛的概念,包括但不限于对数据结构的访问。迭代通常与迭代器关联,而遍历可以应用于多种数据结构和场景。在实现上,迭代与遍历都可以通过编程语言提供的工具和库来简化。

『贰』 详解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迭代相关的资料

热点内容
win8怎么忘记网络 浏览:807
云痕大数据家长怎么登录 浏览:638
用户密码是如何保存在数据库的 浏览:281
联系博导用压缩文件吗 浏览:197
怎么让word文档不显示标记及修改的状态 浏览:980
ug中zg螺纹用什么编程 浏览:306
招标文件里面的格式 浏览:498
shell脚本生成json 浏览:121
会编程对数控有什么帮助 浏览:606
ps导出成矢量文件 浏览:849
公司紧急文件分有哪些 浏览:148
520版本万能钥匙 浏览:849
手机点餐系统app哪个好 浏览:681
scratch编程如何让角色跟着线走 浏览:107
ppt中图片的数据如何编辑 浏览:532
手机只读文件有哪些 浏览:61
微信专清怎么老是显示没有文件 浏览:1
套索工具调整边缘羽化 浏览:112
矩阵式键盘去抖动程序 浏览:794
linux测试程序tps 浏览:185

友情链接