ts for..of vs. for..in 语句
Posted sxdjy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ts for..of vs. for..in 语句相关的知识,希望对你有一定的参考价值。
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
https://www.jianshu.com/p/ff71624a04cc
以上是关于ts for..of vs. for..in 语句的主要内容,如果未能解决你的问题,请参考以下文章
JavaScript ??? 4 ???????????????????????? for VS forEach() VS for/in VS for/of