for in , for of 和forEach三者对比

本文详细对比了JavaScript中的for...in、for...of和forEach三种循环方式。for...in主要用于遍历对象的可枚举属性,不适用于数组;for...of更适合遍历数组、字符串、Map和Set等可迭代对象,且支持中断循环;forEach则用于遍历数组,提供索引但无法中断,不遍历对象的原型属性。
摘要由CSDN通过智能技术生成

for in , for offorEach三者都是循环时经常使用的,但是每个使用场景都是有轻微不同,接下来就进行一个对比

1.1 for…in…的作用

1.1.1 可枚举对象

const person = {
   
  name: 'Lydia',
  age: 21,
};

for (const item in person) {
   
  console.log(item);
}

这个输出结果是: name age

对于这个结果可以简单理解为,对于对象object,使用for…in…循环是对对象的key值进行循环

但是使用for…of…结果就不相同

const person = {
   
  name: 'Lydia',
  age: 21,
};

for (const item of person) {
   
    console.log(item);
  }

这个输出结果TypeError: person is not iterable

这个结果可以看出for…of…不能对对象进行循环

再看看forEach能怎么样?

const person = {
   
  name: 'Lydia',
  age: 21,
}

person.forEach((i) => {
   
  console.log(i)
})

这个输出结果TypeError: person.forEach is not a function

这个结果可以看出forEach不能对对象进行遍历

1.1.2 可枚举数组

 const arr = ['a','b','c']
 
  for (const item in arr) {
   
    console.log(item);
    console.log(arr[item]);
  }

这个输出结果为 0 ‘a’ 1 ‘b’ 2 ‘c’

这个结果看出使用for…in…是输

  • 38
    点赞
  • 261
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值