ts for..of vs. for..in 语句

Posted sxdjy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ts for..of vs. for..in 语句相关的知识,希望对你有一定的参考价值。

1.for..offor..in均可迭代一个列表;但是用于迭代的值却不同,for..in迭代的是对象的  的列表,而for..of则迭代对象的键对应的值。

let list = [4, 5, 6];

for (let i in list) {
    console.log(i); // "0", "1", "2",
}

for (let i of list) {
    console.log(i); // "4", "5", "6"
}

  

2.另一个区别是for..in可以操作任何对象;它提供了查看对象属性的一种方法。 但是 for..of关注于迭代对象的值。内置对象MapSet已经实现了Symbol.iterator方法,让我们可以访问它们保存的值。

let pets = new Set(["Cat", "Dog", "Hamster"]);
pets["species"] = "mammals";

for (let pet in pets) {
    console.log(pet); // "species"
}

for (let pet of pets) {
    console.log(pet); // "Cat", "Dog", "Hamster"
}

  

区别

  1. for...in遍历key值,for...of遍历value值
  2. for...in可以遍历对象或者数组,但是一般不推荐遍历数组,for...of不能遍历普通对象

for...of不能遍历普通对象的原因

原因是:普通对象没有Symbol.iterator属性,如果一个对象拥有Symbol.iterator属性,那么就可以使用for...of遍历

 

来自:https://www.tslang.cn/docs/handbook/iterators-and-generators.html

https://www.jianshu.com/p/ff71624a04cc

 

以上是关于ts for..of vs. for..in 语句的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript ??? 4 ???????????????????????? for VS forEach() VS for/in VS for/of

for each in/for in/for of

for each in 与for in与for of

浅谈for...in与for....of

for each...in for...in for...of

for..in 和 for...of 的区别