js的for in 和 for of的详解

for...infor...of 是 JavaScript 中的两种循环结构,它们用于不同的场景,适用于不同的数据类型。下面将详细介绍它们的用法、区别以及适用场景。

1. for...in 循环

for...in 用于遍历对象的可枚举属性(包括继承的属性)。

语法
javascript 复制代码
for (const key in object) { // 执行代码块 }
示例
javascript 复制代码
const person = { name: 'Alice', age: 25, city: 'New York' }; 
for (const key in person) { 

console.log(key, person[key]) // 输出属性名和对应的值

 }
注意事项
  • for...in 遍历对象时,会遍历其原型链上的可枚举属性。
  • 遍历数组时,虽然可以使用 for...in,但不推荐,因为它会返回数组的索引(字符串形式),可能会导致意外结果。
  • 可以使用 hasOwnProperty() 方法来过滤掉继承的属性。

2. for...of 循环

for...of 用于遍历可迭代对象(如数组、字符串、Map、Set等),直接获取元素的值。

语法
javascript 复制代码
for (const value of iterable) { // 执行代码块 }
示例
javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
 for (const number of numbers) {

 console.log(number); // 输出数组中的每个元素 

}
注意事项
  • for...of 不能用于对象的遍历,只有可迭代对象(如数组、字符串、Map、Set)才能使用。
  • 对于字符串,for...of 会按字符进行遍历。
  • 它不会遍历数组的索引,而是直接访问元素的值,避免了 for...in 可能带来的问题。

3. 总结对比

特性 for...in for...of
遍历对象类型 对象的可枚举属性 可迭代对象(数组、字符串等)
结果 属性名(key) 属性值(value)
遍历方式 包括原型链上的可枚举属性 仅遍历对象本身的元素
不推荐用于 数组(可能导致意外结果) 对象
使用场景 遍历对象的属性 遍历数组、字符串等可迭代对象

4. 使用场景

  • for...in: 当你需要访问对象的属性时,例如处理配置对象、字典或简单的键值对。

    javascript 复制代码
    const settings = { volume: 10, brightness: 70 };
     for (const key in settings) { 
    
    console.log(`${key}: ${settings[key]}`);
    
     }
  • for...of: 当你需要遍历数组或其他可迭代对象的元素时,特别是在处理列表或序列时更为简洁和直观。

    javascript 复制代码
    const fruits = ['apple', 'banana', 'cherry'];
     for (const fruit of fruits) {
    
     console.log(fruit); 
    
    }

5. 结论

在选择使用时,考虑你需要遍历的对象类型和目的,选择最合适的循环结构可以提高代码的可读性和性能。

相关推荐
取经蜗牛2 分钟前
Python 第一阶段完全指南:从零到第一个实用工具
开发语言·python
JNX_SEMI14 分钟前
AT2401C 2.4GHz 全集成射频前端单芯片技术解析
前端·单片机·嵌入式硬件·物联网·硬件工程
anOnion32 分钟前
Agentic 前端开发之 实时显示 AI Agent 终端输出
前端·javascript·人工智能
dog25034 分钟前
从重尾到截断流量模型的演进
开发语言·php
随风一样自由42 分钟前
【前端领域】2026最新前端领域全梳理(框架/工具/AI/跨端/底层标准/就业趋势)
前端·人工智能·前端框架
这是个栗子42 分钟前
【前端性能优化】优化数据加载:用 Promise.all 从串行到并行
前端·javascript·性能优化·异步编程·前端优化·promise.all
qq_401700411 小时前
Qt QSS 完全入门写出漂亮界面以及解决样式不生效问题
开发语言·qt
fei_sun1 小时前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript
大爱一家盟2 小时前
告别卡点BGM同质化 2026原创卡点音乐素材下载网站 TOP5 推荐
大数据·前端·人工智能
彦为君2 小时前
算法思维与经典智力题
java·前端·redis·算法