JavaScript 循环方法对比指南

JavaScript 循环方法对比指南


1. 标准 for 循环

语法:

for (let i = 0; i < arr.length; i++) {console.log(arr[i]);
}

优点

✅ 完全控制索引,适合需要精确控制遍历顺序或步长的场景。
✅ 性能最优,在超大规模数据遍历时比高阶方法(如 forEach)更快。
✅ 支持 break、continue、return,可灵活控制循环流程。

缺点

❌ 代码较冗长,需要手动管理索引。
❌ 不适用于对象遍历(除非结合 Object.keys())。

适用场景

  • 需要基于索引的操作(如逆序遍历、间隔遍历)
  • 性能敏感的场景(如大数据量处理)

2. for…in 循环

语法:

for (const key in obj) {console.log(key, obj[key]);
}

优点

✅ 可遍历对象的所有可枚举属性(包括原型链上的属性)
✅ 适用于普通对象的键值遍历

缺点

❌ 不推荐用于数组,因为会遍历非数字键和原型链属性
❌ 遍历顺序不确定(尤其在涉及继承属性时)
❌ 无法直接获取值,需通过 obj[key] 访问

适用场景

  • 遍历普通对象的属性(需配合 hasOwnProperty 检查)
  • 调试时快速查看对象结构

改进方案

for (const key in obj) {if (obj.hasOwnProperty(key)) {  // 过滤原型链属性console.log(key, obj[key]);
}

3. for…of 循环

语法:

for (const item of iterable) {console.log(item);
}

优点

✅ 直接遍历值,无需手动索引或键名
✅ 支持所有可迭代对象(数组、字符串、Map、Set 等)
✅ 支持 break、continue、return
✅ 代码简洁易读,是"增强 for 循环"的最佳实践

缺点

❌ 不能直接遍历普通对象(需先转换为数组,如 Object.entries(obj))

适用场景

  • 数组或可迭代对象的遍历(推荐替代 forEach)
  • 需要提前终止循环的场景(如查找第一个符合条件的元素)

示例

const arr = [1, 2, 3];
for (const num of arr) {if (num === 2) break;  // 支持 breakconsole.log(num);      // 输出 1
}

4. Array.prototype.forEach

语法:

arr.forEach((item, index) => {console.log(item, index);
});

优点

✅ 函数式编程风格,链式调用方便(如结合 map、filter)
✅ 无需手动管理索引

缺点

❌ 无法中断循环(不支持 break 或 return)
❌ 性能略低于 for 或 for…of(尤其在大数据量时)
❌ 不适用于异步操作(除非配合 async/await 的特殊处理)

适用场景

  • 简单遍历数组且无需中断逻辑
  • 与其他高阶函数(如 map、filter)组合使用

不适用场景

// 错误示例:尝试用 forEach 中断循环
arr.forEach(item => {if (item === 2) break;  // ❌ 报错:Illegal break statement
});

5. 其他遍历方法

方法特点
while / do…while适合条件循环(如读取流数据),但需手动控制终止条件
for await…of异步遍历(如遍历异步生成器或 Promise 数组)
Object.keys() + forEach安全遍历对象属性的替代方案(避免 for…in 的原型链问题)

6. 总结:如何选择循环方法

需求推荐方法
遍历数组且需要中断for…of 或 for
遍历对象属性Object.keys() + forEach 或 for…in(需过滤)
简单数组遍历且无需中断forEach
高性能遍历(大数据量)标准 for 循环
异步遍历for await…of

7. 性能对比(仅供参考)

const largeArray = Array(1e6).fill(0);// 1. 标准 for 循环(最快)
for (let i = 0; i < largeArray.length; i++) {}// 2. for...of(次快)
for (const item of largeArray) {}// 3. forEach(较慢)
largeArray.forEach(() => {});

⚠️ 实际性能差异在大多数场景下可忽略,优先考虑代码可读性!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/85847.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【快餐点餐简易软件】佳易王快餐店点餐系统软件功能及操作教程

一、软件概述与核心优势 &#xff08;一&#xff09;试用版获取方式 资源下载路径&#xff1a;进入博主头像主页第一篇文章末尾&#xff0c;点击卡片按钮&#xff1b;或访问左上角博客主页&#xff0c;通过右侧按钮获取详细资料。 说明&#xff1a;下载文件为压缩包&#xff…

智慧园区数字孪生全链交付方案:降本增效30%,多案例实践驱动全周期交付

在智慧园区建设浪潮中&#xff0c;数字孪生技术正成为破解传统园区管理难题的核心引擎。通过构建与物理园区1:1映射的数字模型&#xff0c;实现数据集成、状态同步与智能决策&#xff0c;智慧园区数字孪生全链交付方案已在多个项目中验证其降本增效价值——某物流园区通过该方案…

从0开始学vue:Element Plus详解

一、核心架构解析二、技术实现指南三、高级特性实现四、性能优化方案五、生态扩展方案六、调试与测试七、版本演进路线 Element Plus 是专为 Vue 3 设计的桌面端 UI 组件库&#xff0c;基于 Vue 3 的 Composition API 重构&#xff0c;在保持与 Element UI 兼容性的同时&#x…

Ubuntu系统配置C++的boost库(含filesystem模块)的方法

本文介绍在具有sudo权限的Ubuntu操作系统中&#xff0c;配置C 的boost库的方法。 boost库是一个广受欢迎的C 库集合&#xff0c;提供了许多强大的功能扩展——例如其中的filesystem模块&#xff0c;可简化文件和目录操作&#xff0c;让开发者可以轻松处理跨平台的文件系统任务。…

Java集合中Stream流的使用

前言 Java 8 引入了 Stream API&#xff0c;它是一种用于处理集合&#xff08;Collection&#xff09;数据的强大工具。Stream 不是数据结构&#xff0c;而是对数据源进行操作的一种方式&#xff0c;支持声明式、函数式的操作&#xff0c;如过滤、映射、排序等。 Stream 操作…

.Net Framework 4/C# 属性和方法

一、属性的概述 属性是对实体特征的抽象&#xff0c;用于提供对类或对象的访问&#xff0c;C# 中的属性具有访问器&#xff0c;这些访问器指定在它们的值被读取或写入时需要执行的语句&#xff0c;因此属性提供了一种机制&#xff0c;用于把读取和写入对象的某些特征与一些操作…

asp.net mvc如何简化控制器逻辑

在ASP.NET MVC中&#xff0c;可以通过以下方法简化控制器逻辑&#xff1a; ASP.NET——MVC编程_aspnet mvc-CSDN博客 .NET/ASP.NET MVC Controller 控制器&#xff08;IController控制器的创建过程&#xff09; https://cloud.tencent.com/developer/article/1015115 【转载…

flask功能使用总结和完整示例

Flask 功能使用总结与完整示例 一、Flask 核心功能总结 Flask 是轻量级 Web 框架&#xff0c;核心功能包括&#xff1a; 路由系统&#xff1a;通过 app.route 装饰器定义 URL 与函数的映射。模板引擎&#xff1a;默认使用 Jinja2&#xff0c;支持动态渲染 HTML。请求处理&…

HarmonyOS应用基础阶段- 09、综合案例-仿携程旅行口碑榜

文章目录 携程-口碑榜1、banner 区域1.1 区域部分1.2 口碑榜 Logo1.3 推荐榜单1.4 评分规则1.5 底部 Line 2、选择城市和目的地2.1 区域布局2.2 选择城市2.3 口碑目的地 3、商业选项菜单4、热门项目选项4.1 区域布局4.2 热门标题4.3 选项 5、热门榜标题6、热门景点列表6.1 区域…

中小制造企业转型:低成本国产工业软件替代方案实践

在数字经济浪潮席卷全球的当下&#xff0c;制造业数字化转型已成为企业提升竞争力、实现可持续发展的必由之路。然而&#xff0c;高昂的成本与复杂的技术门槛&#xff0c;却让众多中小制造企业陷入 “不能转、不想转、不会转、不敢转” 的困局。幸运的是&#xff0c;一批具有自…

Kafka 核心架构与消息模型深度解析(二)

案例实战&#xff1a;Kafka 在实际场景中的应用 &#xff08;一&#xff09;案例背景与需求介绍 假设我们正在为一个大型电商平台构建数据处理系统。该电商平台拥有庞大的用户群体&#xff0c;每天会产生海量的订单数据、用户行为数据&#xff08;如浏览、点击、收藏等&#…

【iOS】cache_t分析

前言 之前分析类的结构的时候&#xff0c;有遇到一个cache_t&#xff0c;当时说是用来保存方法缓存的结构&#xff0c;这篇文章来从源码详细介绍一下cache_t 概览cache_t cache_t结构 类在底层的结构如之前所述&#xff0c;存在着cache_t属性&#xff0c;而cache_t的结构如下…

java面试题:List如何排序?内存溢出/OOM怎么回事?如何排查和解决?

List如何排序 List排序可以通过实现Comparable接口并且实现compareTo方法&#xff0c;或者传入comparator去实现排序。 内存溢出/OOM是怎么回事&#xff1f; 内存溢出就是程序在运行的过程中&#xff0c;申请的内存超过了最大内存限制&#xff0c;导致JVM抛出OOM异常&#x…

Python cryptography【密码库】库功能与使用指南

边写代码零食不停口 盼盼麦香鸡味块 、卡乐比&#xff08;Calbee&#xff09;薯条三兄弟 独立小包、好时kisses多口味巧克力糖、老金磨方【黑金系列】黑芝麻丸 边写代码边贴面膜 事业美丽两不误 DR. YS 野森博士【AOUFSE/澳芙雪特证】377专研美白淡斑面膜组合 优惠劵 别光顾写…

第二十四章 流程控制_ if分支

第二十四章 流程控制: if分支和输入 正如许多编程语言一样Shell也有自己的条件分支语句。有时需要根据情况进行相应的处理&#xff0c;因此可以通过条件分支语句实现&#xff0c;本章主要介绍的是if分支语句。 if语句 在Shell中if语句语法格式如下&#xff1a; if commands…

电脑网络重置,找不到原先自家的WIFI,手机还能正常连接并上网

问题排查&#xff1a;1、电脑感觉网络太慢&#xff0c;因此打算点击了网络重置 2、点击提示会删除网络&#xff0c;在五分钟后关机重启 3、从设备管理器设备的无线wifi属性-事件中发现删除记录 4、选择更新驱动程序 5、从列表中选取 6、更改回老驱动版本 备选方案&#…

C语言_预处理详解

1. 预定义符号 C语言设置了一些预定义符号&#xff0c;可以直接使用&#xff0c;预定义符号也是在预处理期间处理的 1 __FILE__ //进行编译的源文件 2 __LINE__//文件当前的行号 3 __DATE__ //文件被编译的日期 4 __TIME__//文件被编译的时间 5 __STDC__//如果编译器遵循ANSI…

【QT】使用QT帮助手册找控件样式

选择帮助—》输入stylesheet(小写)—》选择stylesheet—》右侧选择Qt Style Sheets Reference 2.使用CtrlF—》输入要搜索的控件—》点击Customizing QScrollBar 3.显示参考样式表–》即可放入QT-designer的样式表中

SQL知识合集(二):函数篇

TRIM函数 作用&#xff1a;去掉字符串前后的空格 SELECT * FROM your_table_name WHERE TRIM(column_name) ; COALESCE函数 作用&#xff1a;返回其参数中的第一个非 NULL 值。它可以接受多个参数&#xff0c;并从左到右依次评估这些参数&#xff0c;直到找到第一个非 NUL…

Cursor 工具项目构建指南: Uniapp Miniprogram 环境下的 Prompt Rules 约束

简简单单 Online zuozuo: 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo : 文章目录 Cursor 工具项目构建指南: Uniapp Miniprogram 环境下的 Prompt Rules 约束前言项目简…