JavaScript 中 for…of 循环迭代数组的正确姿势

javascript 中 for...of 循环迭代数组的正确姿势

本文旨在解决 JavaScript 中使用 for…of 循环迭代数组时遇到的 “is not iterable” 错误。我们将深入探讨 for…of 循环的工作原理,并提供多种正确的迭代数组的方法,包括使用 Array.entries() 获取索引和值,以及对象解构获取数组元素的属性。同时,本文也会对不同迭代方式的性能进行简要分析,帮助开发者选择最适合的方案。

理解 for…of 循环

for…of 循环是 ES6 引入的一种新的循环语法,用于迭代可迭代对象(iterable objects),例如 Array、String、Map、Set、TypedArray、arguments 对象等等。 它的主要作用是直接访问可迭代对象中的,而不是键或索引。

当我们尝试直接在数组上使用 for…of 循环,并期望同时获取键(索引)和值时,就会出现 “is not iterable” 错误。 这是因为 for…of 默认只迭代值,不提供键。

正确使用 for…of 迭代数组

以下是几种正确使用 for…of 循环迭代数组的方法:

立即学习“Java免费学习笔记(深入)”;

1. 使用 Array.entries() 获取索引和值

Array.entries() 方法返回一个新的 Array Iterator 对象,该对象包含数组中每个索引的键/值对。 我们可以使用 for…of 循环来迭代这个迭代器,从而同时获取索引和值。

let collection = [    { name: 'music', views: 20 },    { name: 'abc', views: 32 },    { name: 'bob', views: 20 }];for (const [index, item] of collection.entries()) {    console.log(index, item); // 输出索引和对象}

2. 使用对象解构获取数组元素的属性

如果数组中的元素是对象,并且我们只需要访问对象的某些属性,可以使用对象解构来简化代码。

let collection = [    { name: 'music', views: 20 },    { name: 'abc', views: 32 },    { name: 'bob', views: 20 }];for (const { name, views } of collection) {    console.log(name, views); // 输出 name 和 views 属性}

3. 使用传统的 for 循环

虽然 for…of 循环更简洁,但在某些情况下,传统的 for 循环仍然是最佳选择,特别是当需要更高的性能时。

let collection = [    { name: 'music', views: 20 },    { name: 'abc', views: 32 },    { name: 'bob', views: 20 }];for (let i = 0; i < collection.length; i++) {    console.log(i, collection[i]); // 输出索引和对象}

4. 使用 forEach 方法

forEach 方法是另一种迭代数组的常用方法。 它接受一个回调函数作为参数,该回调函数会被应用到数组中的每个元素。

let collection = [    { name: 'music', views: 20 },    { name: 'abc', views: 32 },    { name: 'bob', views: 20 }];collection.forEach((item, index) => {    console.log(index, item); // 输出索引和对象});

性能考量

不同的迭代方法在性能上可能存在差异。 根据测试,传统的 for 循环通常是最快的,而使用 Array.entries() 可能会稍微慢一些。 forEach 和 for…of 在性能上比较接近,但通常略逊于传统的 for 循环。

因此,在选择迭代方法时,需要根据实际情况进行权衡。 如果性能是关键因素,建议使用传统的 for 循环。 如果代码简洁性更重要,可以选择 forEach 或 for…of 循环。

总结

for…of 循环是 JavaScript 中一种强大的迭代工具,但需要正确使用才能避免错误。 通过理解 for…of 循环的工作原理,并掌握不同的迭代方法,我们可以更有效地处理数组数据。 在选择迭代方法时,需要综合考虑代码简洁性和性能因素,选择最适合的方案。

以上就是JavaScript 中 for…of 循环迭代数组的正确姿势的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1518298.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 11:26:31
下一篇 2025年12月20日 11:26:42

相关推荐

  • JavaScript for…of循环与数组解构:深度解析与性能考量

    本文深入探讨了JavaScript中for…of循环在处理数组时,特别是与解构赋值结合使用时常见的误区。我们将详细解释为何直接对数组元素进行数组解构会导致错误,并提供两种正确且高效的解决方案:使用Array.prototype.entries()获取索引与值,以及利用对象解构直接访问数组…

    2025年12月20日
    000
  • Node.js中如何加密数据?

    Node.js中加密数据需选用合适算法并安全管理密钥。推荐使用AES-256-GCM进行对称加密,因其提供机密性与完整性;RSA配合OAEP填充用于非对称加密,适合密钥交换;密码存储应采用bcrypt等专用哈希算法,避免MD5、SHA1。密钥绝不可硬编码,应通过环境变量、KMS或HSM安全管理,并定…

    2025年12月20日
    000
  • 如何配置JS异地多活?

    异地多活通过CDN、多活源站、GeoDNS、客户端容错和CI/CD协同,实现JS应用跨区域高可用与低延迟,区别于传统灾备的“事后恢复”,其核心是“事前预防”与性能优化。 配置JavaScript应用的异地多活,核心在于构建一个能够跨地理区域提供服务、且在单个区域出现问题时能无缝切换的体系。这不仅仅是…

    2025年12月20日
    000
  • 在HTML的标签中多处显示变量值

    本文将介绍如何在HTML文档的 标签内的多个位置正确显示JavaScript变量的值。核心在于理解HTML中ID属性的唯一性,以及如何使用JavaScript有效地更新多个元素的内容。通过修改HTML结构和JavaScript代码,确保变量值在所有目标位置都能正确呈现。 在Web开发中,经常需要在H…

    2025年12月20日 好文分享
    000
  • 如何配置JS备份策略?

    配置JS备份策略的核心是使用Git进行版本控制并结合云存储定期备份。首先初始化Git仓库,添加文件并提交至本地仓库,再推送到GitHub等远程仓库以防止本地损坏导致数据丢失;同时可创建develop、release等分支管理开发流程。其次,通过编写自动化脚本,利用cron定时将项目打包为ZIP文件并…

    2025年12月20日
    000
  • 如何配置JS国际化?

    配置JS国际化需提取文本并用i18next等库实现多语言支持,核心是解耦UI与文本。首先提取静态文本、错误消息等内容,借助工具避免手动遗漏;接着选择i18next或react-intl等库,前者灵活、跨框架,适合大型项目,后者深度集成React,支持ICU格式化规则;然后初始化库,配置默认语言、翻译…

    2025年12月20日
    000
  • 如何调试时区相关问题?

    答案是调试时区问题需系统性排查配置、代码与客户端。首先确认服务器、数据库及时区库设置正确,检查应用程序是否使用如pytz、java.time等库正确转换时区,避免手动计算偏移;其次通过日志、单元测试、调试器和抓包分析定位问题;确保时间存储采用UTC,传递后再转本地时区,并定期更新时区数据以应对夏令时…

    2025年12月20日
    000
  • 如何配置JS错误跟踪?

    配置JS错误跟踪需选择Sentry等服务,注册获取DSN,集成SDK并初始化,通过window.onerror和onunhandledrejection捕获全局错误与Promise拒绝,结合try…catch处理异常,配置Source Maps还原压缩代码错误位置,注意敏感数据过滤与采样…

    2025年12月20日
    000
  • 如何配置JS代码检查?

    答案:JS代码检查通过工具如ESLint、JSHint、JSLint提前发现代码问题。ESLint因可配置性强、支持TypeScript和JSX、社区活跃成为主流,适合复杂项目;JSHint和JSLint规则固定,适合简单语法检查。集成ESLint需安装Node.js和npm,运行npm insta…

    2025年12月20日
    000
  • 怎样使用Node.js操作枚举?

    Node.js无原生枚举,但可用Object.freeze()模拟或TypeScript实现。纯JS推荐const对象+Object.freeze()确保不可变,TS则提供编译时类型安全、自动补全与更好可维护性,大型项目建议用TS enum并集中管理定义。 Node.js本身在语言层面并没有内置像其…

    2025年12月20日
    000
  • 什么是JS的Map和Set?

    Map和Set是ES6引入的高效数据结构,Map支持任意类型键、保持插入顺序且性能更优,适用于动态键值对存储;Set确保值唯一,常用于数组去重和快速查找。WeakMap与WeakSet通过弱引用避免内存泄漏,适合关联对象元数据。 JavaScript中的 Map 和 Set ,简单来说,它们是ES6…

    2025年12月20日
    000
  • 如何配置JS代码压缩?

    JS代码压缩通过减小文件体积提升加载速度、降低带宽成本、优化SEO并增强代码混淆。其核心方法是使用Webpack等构建工具结合TerserPlugin,在生产模式下自动压缩JS代码。通过配置terserOptions可精细化控制压缩行为,如移除console、混淆变量名、保留特定注释等。常用配置包括…

    2025年12月20日
    000
  • 什么是JS的闭包和作用域?

    闭包是函数与其词法作用域的组合,使函数能访问并记住其外部变量,即使在外部作用域外执行;作用域链决定变量查找路径,从当前作用域逐级向上至全局作用域;常见应用包括私有变量、函数工厂、事件处理,需注意内存泄漏和性能影响。 JavaScript的作用域(Scope)定义了代码中变量和函数的可访问性,它决定了…

    2025年12月20日
    000
  • 如何配置JS故障转移?

    JS故障转移通过冗余备份、异常监控与快速切换保障核心功能。配置多版本JS文件并部署于不同CDN,利用动态加载结合onerror和Promise超时机制检测加载失败,触发备用文件加载;通过Resource Timing API、错误监控平台等多维度监控,结合灰度发布、Feature Flags实现优雅…

    2025年12月20日
    000
  • 如何设置JS代码异常监控?

    答案:JS代码异常监控通过window.onerror、try…catch和unhandledrejection捕获错误,结合Source Map与上报服务实现错误收集;跨域需设置crossorigin和CORS;可模拟异常测试监控有效性。 JS代码异常监控,简单来说,就是捕获并记录Ja…

    2025年12月20日
    000
  • 如何调试打包大小问题?

    首先使用分析工具定位大文件,再通过资源压缩、代码拆分、依赖优化等手段减小打包体积。 调试打包大小问题,关键在于找到占用空间最多的部分,然后逐个优化。这通常涉及到资源优化、代码精简和配置调整。 解决方案: 分析打包文件: 使用工具分析打包后的文件,找出占用空间最大的资源和模块。例如,webpack-b…

    2025年12月20日
    000
  • Node.js中如何操作HTTP头?

    Node.js通过http/https模块操作HTTP头,使用request.headers读取请求头,response.setHeader或res.writeHead设置响应头,注意在发送响应前完成头设置,避免错误;可通过中间件统一处理头信息,如CORS、认证等,结合cookie模块处理Cooki…

    2025年12月20日
    000
  • 怎样查看当前Node.js版本?

    要查看当前Node.js版本,只需在终端输入node -v或node –version,系统将返回类似v18.17.0的版本号,前提是Node.js已正确安装并配置到环境变量。 要查看当前Node.js版本,你只需要打开终端或命令提示符,然后输入 node -v 或 node –ver…

    2025年12月20日
    000
  • 从 Mongoose 数组中移除对象的不同方法

    本文探讨了使用 Mongoose 从 MongoDB 文档的数组中删除特定对象的两种主要方法。第一种方法使用 $pull 操作符,它允许直接在数据库中执行删除操作,从而减少了数据库访问次数。第二种方法首先从数据库中检索文档,然后在内存中过滤数组,最后保存修改后的文档。我们将分析这两种方法的优缺点,并…

    2025年12月20日
    000
  • 使用 Mongoose 从数组中删除对象的最佳实践

    本文旨在探讨在使用 mongoose 从 mongodb 文档的数组字段中删除特定对象时,两种常见方法的优劣。我们将分析 $pull 操作符和 javascript 数组过滤方法,并推荐在不同场景下的最佳实践,以优化数据库操作效率。 在 Mongoose 中,从文档的数组字段中删除特定对象,通常有两…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信