JavaScript如何用for…of遍历数组

1.for…of循环用于遍历数组元素值,语法简洁直观;2.获取索引需结合entries()方法与解构赋值;3.for…of遍历值而for…in遍历键;4.支持break和continue实现中断或跳过。在javascript中,for…of循环专为迭代可迭代对象设计,直接访问数组元素值,如const fruits = [‘苹果’, ‘香蕉’, ‘橙子’]可通过for (const fruit of fruits)依次输出元素。若需获取索引,可用students.entries()返回[index, value]并解构赋值。不同于for…in遍历对象属性名(包括原型链),for…of严格遍历数组元素值,避免意外访问额外属性。此外,for…of支持break提前终止循环或continue跳过当前项,适用于复杂逻辑控制,相较foreach更灵活高效。

JavaScript如何用for...of遍历数组

在JavaScript里,如果你想遍历一个数组,for...of 循环绝对是个非常现代且直观的选择。它允许你直接获取数组中的每个元素的值,而不需要关心索引或者额外的回调函数,让代码读起来更清晰,也更符合我们日常理解的“遍历”概念。

JavaScript如何用for...of遍历数组

解决方案

for...of 循环的设计理念就是为了迭代可迭代对象(iterable objects),而数组恰好就是其中一种。它的语法非常简洁:for (variable of iterable)。这里的 variable 会在每次迭代中被赋值为 iterable(比如你的数组)中的下一个元素的值。

说实话,我个人很喜欢用它来处理数组,因为它真的把重心放在了“值”本身。比如,你有一个水果列表:

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

JavaScript如何用for...of遍历数组

const fruits = ['苹果', '香蕉', '橙子'];for (const fruit of fruits) {  console.log(fruit); // 依次输出:苹果, 香蕉, 橙子}

你看,是不是非常直接?你不需要像传统的 for 循环那样去管理 i 的增减,也不用像 forEach 那样被限制在回调函数里,不能使用 breakcontinue。它就是简单地、优雅地把每个元素摆在你面前。

for...of 循环中如何获取索引?

这确实是一个常见的问题,尤其是当你习惯了传统 for 循环或者 forEach 循环,它们会直接提供索引。for...of 本身是直接遍历值的,它不直接提供索引。但别担心,JavaScript 提供了 entries() 方法,它可以返回一个迭代器,每次迭代会返回一个 [index, value] 的数组。结合解构赋值,就能很优雅地解决这个问题。

JavaScript如何用for...of遍历数组

const students = ['小明', '小红', '小刚'];// 使用 entries() 和解构赋值for (const [index, student] of students.entries()) {  console.log(`学生 ${index + 1}: ${student}`);}// 输出:// 学生 1: 小明// 学生 2: 小红// 学生 3: 小刚

我觉得这种方式挺巧妙的,它并没有破坏 for...of 的核心设计理念,即遍历值,同时又提供了一种灵活的方式来获取额外的上下文信息(比如索引)。这比你手动维护一个计数器要好得多,代码也更具可读性。

for...offor...in 的根本区别

这是一个非常重要的点,也是很多初学者容易混淆的地方。尽管它们看起来有点像,但它们的用途和遍历对象完全不同。简单来说,for...of 遍历的是,而 for...in 遍历的是键(key)或者说属性名

for...in 主要用于遍历对象的可枚举属性,包括原型链上的属性。当你把它用在数组上时,它会返回数组的索引(字符串类型),而不是数组元素的值。而且,它还会遍历到数组对象上可能存在的其他属性,这在某些情况下可能会导致意想不到的结果。

const colors = ['red', 'green', 'blue'];colors.customProperty = 'colorful'; // 给数组添加一个自定义属性console.log('--- for...of 遍历数组 ---');for (const color of colors) {  console.log(color); // 输出:red, green, blue}console.log('n--- for...in 遍历数组 ---');for (const key in colors) {  console.log(key); // 输出:0, 1, 2, customProperty  console.log(typeof key); // 输出:string  console.log(colors[key]); // 输出:red, green, blue, colorful}

从上面的例子可以看出,for...of 严格地只关心数组的元素值,而 for...in 却把索引和我们额外添加的属性都遍历出来了。所以,如果你想遍历数组的元素,请务必使用 for...offor...in 更适合用来遍历普通对象的属性。我个人在处理数组时,几乎不会考虑 for...in,它真的很容易让人掉坑里。

如何在 for...of 循环中中断或跳过?

这是 for...of 相对于 forEach 的一个显著优势。forEach 方法本身是无法中断的,你不能在它的回调函数中使用 breakcontinue 来跳出循环或跳过当前迭代。如果你需要这样的控制流,通常得用 try...catch 包裹一个抛出的错误,或者用 some() / every() 来模拟,但这都显得不够自然。

for...of 循环则完全支持 breakcontinue 语句,这让它在处理需要条件判断和提前终止的场景时,显得非常灵活和强大。

const numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];console.log('--- 找到第一个大于5的数后停止 ---');for (const num of numbers) {  if (num > 5) {    console.log(`找到了第一个大于5的数: ${num}`);    break; // 找到后立即停止整个循环  }  console.log(`当前数字: ${num}`);}// 输出:// 当前数字: 1// 当前数字: 2// 当前数字: 3// 当前数字: 4// 当前数字: 5// 找到了第一个大于5的数: 6console.log('n--- 跳过偶数,只处理奇数 ---');for (const num of numbers) {  if (num % 2 === 0) {    continue; // 跳过当前迭代,进入下一次循环  }  console.log(`处理奇数: ${num}`);}// 输出:// 处理奇数: 1// 处理奇数: 3// 处理奇数: 5// 处理奇数: 7// 处理奇数: 9

这种能力让 for...of 在处理复杂逻辑时显得更加直观和高效。我觉得,如果你的遍历逻辑中涉及到任何形式的提前退出或跳过,for...of 几乎是你的首选,它让代码的意图表达得非常清晰。

以上就是JavaScript如何用for…of遍历数组的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 05:25:20
下一篇 2025年12月20日 05:25:32

相关推荐

  • JavaScript中异步迭代的实现方式

    javascript中实现异步迭代的核心在于利用for await…of循环配合实现了symbol.asynciterator接口的对象,使得处理异步数据流如同同步遍历一样直观。1. 异步迭代依赖于symbol.asynciterator协议,要求对象必须有一个以该符号为键的方法,返回一…

    2025年12月20日 好文分享
    000
  • JavaScript的removeChild方法是什么?如何使用?

    javascript的removechild方法用于从父节点中移除指定的子节点,但被移除的节点仍保留在内存中可被重新使用。1.使用时需先获取父节点和子节点,语法为var removedchild = parentnode.removechild(childnode); 2.该方法返回被移除的节点,便…

    2025年12月20日 好文分享
    000
  • Puppeteer 自动化:捕获动态按钮触发的网络请求URL

    本文详细介绍了如何在使用 Puppeteer 自动化操作时,获取那些不直接暴露链接的按钮所触发的动态下载或API请求的URL。通过利用 Puppeteer 的网络请求拦截功能,结合 page.waitForRequest 方法,您将学习如何在点击按钮后捕获并解析其背后的实际数据源链接,从而实现对动态…

    2025年12月20日
    000
  • 使用 Puppeteer 自动化获取动态下载按钮链接的策略

    本文详细介绍了如何利用 Puppeteer 应对网页中不直接暴露下载链接的动态按钮。通过拦截网络请求,特别是利用 page.waitForRequest 监听特定类型的请求,可以精准捕获到由按钮点击触发的实际下载 URL。教程涵盖了从环境搭建、页面导航、模拟点击到请求捕获的全过程,并提供了详细的代码…

    2025年12月20日
    000
  • React Router v6:构建受保护的嵌套路由与动态仪表盘布局

    或 <route path="*" element="{} /> 来处理用户访问不存在的 URL 的情况,提升用户体验。加载状态与错误处理:在实际的 ProtectedRoute 中,你可能需要处理异步认证检查时的加载状态,以及认证失败时的错误提示。 通过上…

    2025年12月20日
    000
  • React Router v6 中嵌套路由与保护路由的实现指南

    表示当 URL 精确匹配到 /dashboard 时,WelcomeDashboard 组件将被渲染到 Layout 的 Outlet 中。这是一个很好的实践,为父路由提供默认内容。Navigate 组件: 当需要进行程序化导航或重定向时,Navigate 组件非常有用。在 ProtectedRou…

    2025年12月20日
    000
  • ES6的数组缓冲区如何操作二进制数据

    es6中操作arraybuffer的核心方法是创建缓冲区并使用typedarray视图读写数据。1. 创建arraybuffer:使用new arraybuffer(size)创建固定大小的缓冲区;2. 创建视图:通过uint8array、int32array等视图按特定类型解读数据;3. 读写数据…

    2025年12月20日 好文分享
    000
  • JavaScript如何用空值合并运算符设置默认值

    javascript的空值合并运算符(??)与逻辑或(||)的核心差异在于判断“空值”的标准不同。1. ?? 运算符仅当左侧为 null 或 undefined 时才返回右侧操作数,保留 0、false 和 ” 等有效值;2. || 运算符基于“假值”判断,遇到 0、false、&#82…

    2025年12月20日 好文分享
    000
  • JavaScript如何用includes检查数组包含

    includes() 方法能快速判断数组是否包含特定元素,返回布尔值。1. 使用方式简单,直接传入要查找的值即可,如 fruits.includes(‘banana’) 返回 true;2. 支持从指定索引开始查找,如 fruits.includes(‘apple…

    2025年12月20日 好文分享
    000
  • ES6中如何用Array.from转换类数组

    array.from() 是 es6 中用于将类数组对象或可迭代对象转换为新数组的方法。其语法为 array.from(arraylike, mapfn, thisarg),其中 arraylike 是必填参数,表示要转换的对象;mapfn 和 thisarg 为可选参数,分别用于元素映射和指定 t…

    2025年12月20日 好文分享
    000
  • ES6中如何用数组的fill方法填充元素

    fill()方法常见应用场景有四:1.创建并初始化固定长度数组;2.重置数组特定部分;3.算法中使用全值数组作为初始状态;4.填充占位符或默认值数组。例如new array(10).fill(0)快速生成十个零,gameboard.fill(null, 2, 5)清空棋盘部分区域,visitedno…

    2025年12月20日 好文分享
    000
  • JavaScript如何用Reflect操作对象原型

    reflect操作对象原型的核心方法是reflect.getprototypeof()和reflect.setprototypeof()。reflect.getprototypeof(target)用于获取target对象的原型,返回其[[prototype]]值,若target非对象或无法获取则返…

    2025年12月20日 好文分享
    000
  • JavaScript的void操作符是什么?怎么用?

    javascript的void操作符用于执行表达式并返回undefined。其核心作用是确保表达式结果为undefined,常见于早期阻止链接跳转的场景,如href=”javascript:void(0);”,但现代开发中已较少使用。1. void(expression)会执…

    2025年12月20日 好文分享
    000
  • JavaScript如何用数组的findIndex查找位置

    javascript数组的findindex方法用于查找第一个满足条件的元素索引,若未找到则返回-1。其核心作用是通过回调函数对数组每个元素进行测试,一旦某个元素使回调返回true,则立即返回该元素索引;否则遍历完数组后返回-1。使用时需注意以下要点:1. 回调函数可接收element、index和…

    2025年12月20日 好文分享
    000
  • React组件跨域嵌入与样式隔离指南

    本教程详细阐述了如何在外部域中嵌入React组件并确保其样式正确加载与隔离。通过结合Webpack进行CSS打包注入JavaScript,并利用CSS Modules实现类名哈希化,可以有效避免样式冲突,实现组件的自包含部署。文章提供了具体的配置步骤、代码示例及注意事项,帮助开发者构建可复用、无副作…

    2025年12月20日
    000
  • React组件跨域导出与样式封装指南

    本文详细阐述了如何将React组件及其样式安全地导出并嵌入到外部Web页面中,解决了传统方法中样式丢失和命名冲突的问题。通过利用Webpack进行样式内联打包以及CSS Modules实现样式隔离,确保组件在外部环境中保持其预期的视觉效果,同时避免对宿主页面的影响,提供了一套专业且高效的解决方案。 …

    2025年12月20日
    000
  • JavaScript如何用find方法查找数组元素

    javascript的find方法用于查找数组中第一个满足条件的元素。1. 它通过遍历数组,对每个元素执行提供的回调函数,一旦找到符合条件的元素即返回该元素;2. 若遍历结束未找到,则返回undefined;3. 回调函数接收三个参数:当前元素、当前索引(可选)、原数组(可选);4. 与filter…

    2025年12月20日 好文分享
    000
  • JavaScript的Array.prototype.find方法是什么?如何使用?

    array.prototype.find 用于查找数组中满足条件的第一个元素。1. 它接受一个回调函数,回调接收 element、index(可选)、array(可选)三个参数;2. 回调返回 true 时即刻返回当前元素,否则继续遍历;3. 若未找到则返回 undefined;4. 与 findi…

    2025年12月20日 好文分享
    000
  • JavaScript中异步代码调试技巧

    javascript异步代码调试的核心在于理解事件循环机制,并结合开发者工具与特定技巧。1. 使用debugger语句和条件断点可精准控制暂停时机;2. 利用console.trace()追踪调用栈以理清执行流程;3. 启用浏览器开发者工具的“async”选项并结合network面板分析请求;4. …

    2025年12月20日 好文分享
    000
  • JavaScript的createElement方法是什么?如何创建元素?

    createelement用于动态创建html元素节点。1. createelement创建的是dom对象,允许细粒度控制和事件绑定,安全性更高;2. innerhtml操作的是html字符串,适合简单内容填充但存在xss风险;3. 创建后需用appendchild、insertbefore等方法将…

    2025年12月20日 好文分享
    000

发表回复

登录后才能评论
关注微信