JavaScript 中的 for...in 和 for...of 循环详解

news2025/5/18 13:06:06

在 JavaScript 中,for...in 和 for...of 是两种常用的循环结构,但它们有着不同的用途和行为。很多初学者容易混淆这两者,本文将详细解析它们的区别、适用场景以及注意事项。

目录

  1. for…in 循环

    • 基本用法
    • 遍历对象属性
    • 注意事项
  2. for…of 循环

    • 基本用法
    • 可迭代对象
    • 与数组的结合使用
  3. 主要区别对比

  4. 何时使用哪种循环

  5. 实际应用示例

  6. 总结

for…in 循环

基本用法

for...in 语句用于遍历对象的可枚举属性(包括原型链上的可枚举属性)。

for (variable in object) {
  // 执行的代码
}

遍历对象属性

const person = {
  name: 'Alice',
  age: 25,
  occupation: 'Developer'
};

for (const key in person) {
  console.log(`${key}: ${person[key]}`);
}
// 输出:
// name: Alice
// age: 25
// occupation: Developer

注意事项

  1. 遍历顺序不保证for...in 不保证属性的遍历顺序,特别是在不同 JavaScript 引擎中可能有差异。

  2. 会遍历原型链上的属性

    function Person() {
      this.name = 'Bob';
    }
    Person.prototype.age = 30;
    
    const bob = new Person();
    
    for (const prop in bob) {
      console.log(prop); // 输出 name 和 age
    }
    

    可以使用 hasOwnProperty() 来过滤:

    for (const prop in bob) {
      if (bob.hasOwnProperty(prop)) {
        console.log(prop); // 只输出 name
      }
    }
    
  3. 不推荐用于数组

    const arr = ['a', 'b', 'c'];
    
    for (const index in arr) {
      console.log(index); // 输出 "0", "1", "2"
    }
    

    虽然可以工作,但有潜在问题(如可能遍历到非数字属性)。

for…of 循环

基本用法

for...of 语句在可迭代对象(包括 Array, Map, Set, String, TypedArray, arguments 对象等)上创建一个迭代循环。

for (variable of iterable) {
  // 执行的代码
}

可迭代对象

for...of 只能用于实现了 [Symbol.iterator] 方法的对象:

const arr = ['a', 'b', 'c'];

for (const value of arr) {
  console.log(value); // 输出 "a", "b", "c"
}

const str = 'hello';
for (const char of str) {
  console.log(char); // 输出 "h", "e", "l", "l", "o"
}

const set = new Set([1, 2, 3]);
for (const num of set) {
  console.log(num); // 输出 1, 2, 3
}

const map = new Map([['a', 1], ['b', 2]]);
for (const [key, value] of map) {
  console.log(`${key}: ${value}`); // 输出 "a: 1", "b: 2"
}

与数组的结合使用

for...of 是遍历数组元素的理想选择:

const fruits = ['apple', 'banana', 'orange'];

for (const fruit of fruits) {
  console.log(fruit);
}
// 输出:
// apple
// banana
// orange

主要区别对比

特性for…infor…of
用途遍历对象属性遍历可迭代对象的值
返回值属性名(key)属性值(value)
可遍历对象任意对象可迭代对象(Array, Map等)
遍历原型链属性
数组遍历遍历索引(字符串)遍历元素值
性能相对较慢相对较快
引入版本ES1ES6

何时使用哪种循环

  • 使用 for...in 当

    • 需要遍历对象的所有可枚举属性
    • 需要检查对象是否具有某些属性
    • 需要遍历原型链上的属性(或明确使用 hasOwnProperty 过滤)
  • 使用 for...of 当

    • 需要遍历数组的元素值
    • 需要遍历其他可迭代对象(Map, Set等)的值
    • 需要更简洁的语法且不关心索引/键
  • 都不使用时

    • 对于简单的数组遍历,传统的 for 循环有时性能更好
    • 需要中断循环时,forEach 无法使用 break,此时 for...of 更合适

实际应用示例

示例1:对象属性操作

const user = {
  id: 1,
  name: 'John Doe',
  email: 'john@example.com',
  isAdmin: false
};

// 使用 for...in 将所有布尔属性转换为字符串
for (const key in user) {
  if (typeof user[key] === 'boolean') {
    user[key] = user[key].toString();
  }
}

console.log(user); // isAdmin 现在是 "false"

示例2:数组元素处理

const scores = [85, 92, 78, 95, 88];
let total = 0;

// 使用 for...of 计算总分
for (const score of scores) {
  total += score;
}

console.log(`平均分: ${total / scores.length}`); // 平均分: 87.6

示例3:结合解构赋值

const users = [
  { id: 1, name: 'Alice' },
  { id: 2, name: 'Bob' },
  { id: 3, name: 'Charlie' }
];

// 使用 for...of 和解构
for (const { id, name } of users) {
  console.log(`用户ID: ${id}, 姓名: ${name}`);
}

总结

  • for...in 用于遍历对象的可枚举属性,包括原型链上的属性
  • for...of 用于遍历可迭代对象的值,如数组元素、Map/Set 的项等
  • 对于数组遍历,优先使用 for...of 而不是 for...in
  • 两种循环各有适用场景,理解它们的差异有助于写出更清晰、更高效的代码

掌握 for...in 和 for...of 的区别和正确用法,将使你在 JavaScript 开发中能够更灵活地处理各种数据结构和对象遍历需求。

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

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

相关文章

Spark,连接MySQL数据库,添加数据,读取数据

连接数据库 可以看到shell中我们读取出的数据 在IDEA中打代码如果能输出跟shell中一样的结果即证明连接成功 【出错反思】 像我前面出错的原因就是在打代码时将密码输入错误 添加数据 读取数据就是在上面代码中一起展示了,这里我就不单独说了

【EDA软件】【联合Modelsim仿真使用方法】

背景 业界EDA工具仿真功能是必备的,例如Vivado自带仿真工具,且无需联合外部仿真工具,例如MoodelSim。 FUXI工具仿真功能需要联合Modelsim,才能实现仿真功能。 方法一:FUXI联合ModelSim 1 添加testbench文件 新建to…

【离散化 线段树】P3740 [HAOI2014] 贴海报|普及+

本文涉及知识点 C线段树 [HAOI2014] 贴海报 题目描述 Bytetown 城市要进行市长竞选,所有的选民可以畅所欲言地对竞选市长的候选人发表言论。为了统一管理,城市委员会为选民准备了一个张贴海报的 electoral 墙。 张贴规则如下: electoral…

CSP 2024 提高级第一轮(CSP-S 2024)单选题解析

单选题解析 第 1 题 在 Linux 系统中,如果你想显示当前工作目录的路径,应该使用哪个命令?(A) A. pwd B. cd C. ls D. echo 解析:Linux 系统中,pwd命令可以显示当前工作目录的路径。pwd&#x…

六、绘制图片

文章目录 1.创建一个红色图片2.加载bmp图片3.加载png、jpg图片 前面的几个示例,我们已经展示过如果在Linux系统下使用xlib接口向窗口中绘制文本、线、矩形;并设置文本、线条的颜色。并利用xlib提供的接口结合事件处理机制完成了一个自绘按钮控件功能。有…

Java 面向对象详解和JVM底层内存分析

先关注、点赞再看、人生灿烂!!!(谢谢) 神速熟悉面向对象 表格结构和类结构 我们在现实生活中,思考问题、发现问题、处理问题,往往都会用“表格”作为工具。实际上,“表格思维”就是…

深度学习---知识蒸馏(Knowledge Distillation, KD)

一、知识蒸馏的本质与起源 定义: 知识蒸馏是一种模型压缩与迁移技术,通过将复杂高性能的教师模型(Teacher Model)所学的“知识”迁移到轻量级的学生模型(Student Model),使学生模型在参数量和计…

基于CNN卷积神经网络的带频偏QPSK调制信号检测识别算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2024b 3.部分核心程序 (完整版代码包含详细中文注释和操作步骤视频&#xff09…

【DAY21】 常见的降维算法

内容来自浙大疏锦行python打卡训练营 浙大疏锦行 目录 PCA主成分分析 t-sne降维 线性判别分析 (Linear Discriminant Analysis, LDA) 作业: 什么时候用到降维 降维的主要应用场景 知识点回顾: PCA主成分分析t-sne降维LDA线性判别 通常情况下,…

校园社区小程序源码解析

基于ThinkPHP、FastAdmin和UniApp开发的校园社区小程序源码,旨在为校园内的学生和教职员工提供一个便捷的在线交流和服务平台。 该小程序前端采用UniApp进行开发,具有良好的跨平台兼容性,可以轻松发布到iOS和Android平台。同时,后…

第6章:文件权限

一、文件权限概述 Linux为了保证系统中每个文件的安全,引入了文件权限机制。针对于系统中的每一个文件Linux都可以提供精确的权限控制。它可以做到不同的用户对同一个文件具有不同的操作权利。而通常这个权利包括以下3个: 读的权利(Read&…

C语言| 指针变量的定义

C语言| 指针的优点-CSDN博客 * 表示“指向”,为了说明指针变量和它所指向的变量之间的联系。 int * i;//表示指针变量i里面存放的地址,所指向的存储单元里的【数据】。 【指针变量的定义】 C语言规定所有变量,在使用前必须先定…

IntelliJ IDEA给Controller、Service、Mapper不同文件设置不同的文件头注释模板、Velocity模板引擎

通过在 IntelliJ IDEA 中的 “Includes” 部分添加多个文件头模板,并在 “Files” 模板中利用这些包含来实现不同类型文件的注释。以下是为 Controller、Service、Mapper 文件设置不同文件头的完整示例: 1. 设置 Includes 文件头模板 File > Settin…

【论文阅读】BEVFormer

〇、Introduction BEVFormer是现在端到端无人驾驶中常使用的一个Backbone,用于将六个视角下的图像转换为鸟瞰图视角下的特征,转换出的BEV特征则会被用于后续模块的特征交互。然而在这个模型设计的初期,其最本质的意图是为了提取用于各种CV任…

IDEA编辑器设置的导出导入

背景 最近新换了电脑,因为之前是 Intel 芯片的 Mac,这次换了 arm 架构的 M 芯片的 Mac,旧 Mac 上的很多软件不兼容,所以就没有选择换机数据迁移,一点一点下载、配置了所有环境。 导出 IDEA 支持设置的导入导出&…

成功案例丨从草图到鞍座:用先进的发泡成型仿真技术变革鞍座制造

案例简介 在鞍座制造中,聚氨酯泡沫成型工艺是关键环节,传统依赖实验测试的方法耗时且成本高昂。为解决这一问题,意大利自行车鞍座制造商 Selle Royal与Altair合作,采用Altair Inspire PolyFoam软件进行发泡成型仿真。 该工具帮助团…

电机试验平台:创新科技推动电动机研究发展

电机试验平台是电机制造和研发过程中不可或缺的重要设备,其功能涵盖了电机性能测试、电机寿命测试、电机质量评估等多个方面。随着科技的不断发展和电机应用领域的日益扩大,对电机试验平台的要求也越来越高。本文将从现代化电机试验平台的设计与应用两个…

【springcloud学习(dalston.sr1)】Zuul路由访问映射规则配置及使用(含源代码)(十二)

该系列项目整体介绍及源代码请参照前面写的一篇文章【springcloud学习(dalston.sr1)】项目整体介绍(含源代码)(一) springcloud学习(dalston.sr1)系统文章汇总如下: 【springcloud学习(dalston…

Qt与Hid设备通信

什么是HID? HID(Human Interface Device)是‌直接与人交互的电子设备‌,通过标准化协议实现用户与计算机或其他设备的通信,典型代表包括键盘、鼠标、游戏手柄等。‌ 为什么HID要与qt进行通信? 我这里的应…

2024 山东省ccpc省赛

目录 I(签到) 题目简述: 思路: 代码: A(二分答案) 题目简述: 思路: 代码: K(构造) 题目: 思路: 代…