1.for..of
和for..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
关注于迭代对象的值。内置对象Map
和Set
已经实现了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" }
区别
- for...in遍历key值,for...of遍历value值
- for...in可以遍历对象或者数组,但是一般不推荐遍历数组,for...of不能遍历普通对象
for...of不能遍历普通对象的原因
原因是:普通对象没有Symbol.iterator属性,如果一个对象拥有Symbol.iterator属性,那么就可以使用for...of遍历
来自:https://www.tslang.cn/docs/handbook/iterators-and-generators.html