for in 和 for of区别

本文探讨了JavaScript中for...in和for...of循环的区别,包括它们如何遍历对象、数组的不同行为,以及在枚举属性和可迭代值上的侧重点。通过实例演示,展示了for...in用于原型链遍历,而for...of专为数组元素和迭代器设计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

for in 和for of区别

先看一下官方文档的介绍
在这里插入图片描述
示例:

Object.prototype.objCustom = function() {};
Array.prototype.arrCustom = function() {};

let iterable = [3, 5, 7];
iterable.foo = 'hello';

//每个对象将继承objCustom属性,并且作为Array的每个对象将继承arrCustom属性,
//因为将这些属性添加到Object.prototype (en-US)和Array.prototype。
//由于继承和原型链,对象iterable继承属性objCustom和arrCustom。


for (let i in iterable) {
  console.log(i); // logs 0, 1, 2, "foo", "arrCustom", "objCustom"
}
//此循环仅以原始插入顺序记录iterable 对象的可枚举属性。
//它不记录数组元素3, 5, 7 或hello,因为这些不是枚举属性。
//但是它记录了数组索引以及arrCustom和objCustom。

for (let i in iterable) {
  if (iterable.hasOwnProperty(i)) {
    console.log(i); // logs 0, 1, 2, "foo"
  }
}
//这个循环类似于第一个,但是它使用hasOwnProperty() 来检查,如果找到的枚举属性是对象自己的(不是继承的)。
//如果是,该属性被记录。记录的属性是0, 1, 2和foo,因为它们是自身的属性(不是继承的)。
//属性arrCustom和objCustom不会被记录,因为它们是继承的。

for (let i of iterable) {
  console.log(i); // logs 3, 5, 7
}
//该循环迭代并记录iterable作为可迭代对象定义的迭代值,这些是数组元素 3, 5, 7,而不是任何对象的属性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值