当前位置: 首页 > news >正文

for forin forof forEach map区别

一、总结

  1. 相同点:都是串行遍历。
  2. 不同点:
    遍历方法对比

二、for of循环

  1. 设计目的:遍历所有数据结构的统一方法
  2. 原理:会调用数据结构的Symbol.iterator方法。
    • 只要数据结构定义了Symbol.iterator属性,就能用for of遍历它的成员。
    • 换句话说,只要能被for of遍历,数据结构上一定有Iterator接口。
  3. 适用范围:数组、set、map、类数组(arguments对象、Dom NodeList对象)、生成器对象、字符串。
  4. 可以中断(支持break/continue), 支持return。
  5. 数组的遍历器:只返回能通过数字下标访问的属性。

三、for in循环

  1. 为了遍历对象而设计。能够遍历数组的key。

  2. 缺点:

    • 数组的索引是数字,但是for in里拿到的键值是字符串。
    • for in还会遍历数组上挂载的其他属性;如果数组原型被重写(新增变量),还会访问到原型链上的值。
    • 特殊场景:如果对象键值是数字,则会按照键值的升序来遍历。

四、map forEach

相同点:

  1. 为了解决for遍历数组,写法太麻烦。
  2. 无法中途跳出循环。break、continue都不支持。

不同点:

  1. map支持return, 会新开辟内存接收返回值。
  2. forEach不支持return, 没有返回值。
http://www.lryc.cn/news/171826.html

相关文章:

  • 特殊时间(蓝桥杯)
  • VUE路由与nodeJS环境搭建
  • 抗锯齿的线
  • 如何使用高压放大器驱动高容性负载
  • kubernetes集群证书过期启动失败问题解决方法
  • nvm使用的注意事项和常用命令。
  • 代码大全阅读随笔(七)
  • 用户与权限管理
  • mysql集群使用nginx配置负载均衡
  • 蓝桥杯每日一题2023.9.21
  • 知识联合——函数指针数组
  • 【Nginx26】Nginx学习:日志与镜像流量复制
  • Stability AI发布基于稳定扩散的音频生成模型Stable Audio
  • 华为OD机试 - 计算面积 - 逻辑分析(Java 2023 B卷 100分)
  • Ganache本地测试网+cpolar内网穿透实现公网访问内网
  • 【每日一题】ARC071D - ### | 前缀和 | 简单
  • (Vue2)VueRouter
  • 6.文本注释方法
  • [Linux打怪升级之路]-缓冲区
  • 【力扣】13. 罗马数字转整数
  • 高效时间管理,事无巨细掌握——OmniFocus Pro 3 for Mac最强GTD工具
  • 解锁前端Vue3宝藏级资料 第五章 Vue 组件应用 3( Slots )
  • 接口测试之文件上传
  • 7.Flask-Migrate数据库迁移
  • 信创办公–基于WPS的PPT最佳实践系列 (项目8创建电子相册)
  • JRedis的基本操作,基本数据类型操作
  • QT网页 webengine / CEF
  • Golang笔试题:编写一个函数,接收一个整数参数n,输出n的阶乘结果
  • 外包干了2个月,技术退步明显.......
  • 无涯教程-JavaScript - BINOM.DIST函数