JS for in 与 for of 的区别

for in 是ES5标准,遍历的是key(可遍历对象,数组和字符串的key)

for of 是ES6标准,遍历的是value(可遍历对象,数组和字符串的value)

一、for in

for in 用来循环数组不是一个合适的选择 ,使用for...in可以遍历数组,但会存在以下问题:

  • index索引为字符串型数字(数字,非数字),不能进行集合运算
  • 遍历顺序有可能不是按照实际数组的内部顺序(可能按照随机顺序)
  • 使用for-in会遍历数组所有的可枚举属性,包括原型。原型方法method和name属性都会被遍历出来,通常需要配合hasOwnProperty()方法判断某个属性是否该对象的实例属性,来将原型对象从循环中剔除。
  • 如果迭代的对象的变量值是null或者undefined, for in不执行循环体,建议在使用for in循环之前,先检查该对象的值是不是null或者undefined

for in 应用于数组中

Array.prototype.sayHello = function(){
    console.log('hello');
}

Array.prototype.str = 'world'
var myArray = [1,2,10,30,34]
myArray.name = '数组'
for (const key in myArray) {
    console.log(key);
}
//迭代的是属性key,不是值。
//结果 0 1 2 3 4 name sayHello str

for in 应用于对象中

Object.prototype.sayHello = function(){
    console.log('hello');
}
Object.prototype.str = 'world'
var myObject = {name:'dd',age:12}
for (const index in myObject) {
    console.log(index);
}
//结果 name age sayHello str 首先输出的是对象的属性名,再是对象原型中的属性和方法

hasOwnProperty方法

如果不想让其输出原型中的属性和方法,可以使用 hasOwnProperty方法进行过滤

Object.prototype.sayHello = function(){
    console.log('hello');
}
Object.prototype.str = 'world'
var myObject = {name:'dd',age:12}
for (const index in myObject) {
    if (myObject.hasOwnProperty(index)) {
        console.log(index);
    }
}
//结果 name age

二、for of

for..of适用遍历数/数组对象/字符串/map/set等拥有迭代器对象的集合.但是不能遍历对象,因为没有迭代器对象.

for...of循环不会循环对象的key,只会循环出数组的value,因此for...of不能循环遍历普通对象,对普通对象的属性遍历推荐使用for...in

如果实在想用for...of来遍历普通对象的属性的话,可以通过和Object.keys()搭配使用,先获取对象的所有key的数组

var obj = {
    name:'zhangsan',
    age:18,
    skil:{
      say:'hello',
      eat:'fruit'
    }
  }
  for(let key of obj){
    consoloe.log(key);
  }//报错
  for (const key of Object.keys(obj)) {
    //使用Object.keys()方法获取对象key的数组
    console.log(key+":"+obj[key]);
  }
var myObject = {
    name:'zhangsan',
    age:10
  }
  var arr = [1,2,3,4,5]
    
  for(let key of myObject){
    consoloe.log(key);
  }
  //输出结果
  //typeError
  for (const key of arr) {
    console.log(key); //1 2 3 4 5
  }
  
  for (let key in myObject) {
    console.log(key); //name age
    console.log(myObject[key]); //zhangsan 10
  }

  for (const key in arr) {
    console.log(key); // 0 1 2 3 4 得到下标
    console.log(arr[key]); // 0 1  1 2  2 3  3 4  4 5 得到索引和值
  }

三、总结

for in遍历的是数组的索引(即键名),而for of遍历的是数组元素值

for in总是得到对象的key或数组、字符串的下标

for of总是得到对象的value或数组、字符串的值

### JavaScript 中 `for...in` `for...of` 循环的区别 #### 基本概念 `for...in` 是一种用于遍历对象属性的语句,而 `for...of` 则是用来迭代可迭代对象(如数组、字符串、Map、Set 等)中的值。两者的用途不同,适用场景也有所差异。 #### `for...in` 的特点 `for...in` 遍历的是对象自身的以及继承的可枚举属性名[^2]。它通常被用来访问对象的所有键(即属性名称)。需要注意的是,`for...in` 不仅会返回对象本身的属性,还会返回通过原型链继承来的属性。因此,在处理数组时可能会导致意外的结果,因为数组也是对象的一种形式,并且可能具有额外的方法或属性。 ```javascript const obj = { key1: 'value1', key2: 'value2' }; for (let prop in obj) { console.log(prop); // 输出 "key1", "key2" } ``` #### `for...of` 的特点 相比之下,`for...of` 提供了一种更直观的方式来获取集合类型的值,而不是它们的索引或者键[^4]。它可以作用于任何实现了 Iterable 接口的数据结构之上,比如 Array、String、TypedArray、NodeList 或者 Map/Set 等等。对于这些数据类型来说,每次循环都会提取当前项的实际内容而非其位置信息。 ```javascript const array = ['a', 'b', 'c']; for (let elem of array) { console.log(elem); // 输出 "a", "b", "c" } ``` #### 主要区别总结 | 特性 | for...in | for...of | |---------------------|-----------------------------------|------------------------------| | **主要功能** | 遍历对象的属性 | 获取可迭代对象中的具体值 | | **目标范围** | 所有可枚举属性(包括原型上的方法)| 可迭代对象的内容 | | **性能考虑** | 较慢 | 更高效 | 尽管两者名字相似,但实际应用场景完全不同;如果只是想简单地读取列表里的每一个成员,则应该优先选用效率更高的 `for...of` 而不是容易引起误解甚至错误使用的 `for...in`. ```javascript // 使用for...of来打印数组元素 let letters = ["A", "B", "C"]; for(let letter of letters){ console.log(letter); } // 使用for...in则需注意不要误用到数组上 let numbers = [10, 20 ,30]; for(let index in numbers){ console.log(numbers[index]); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值