码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2020-06-29 11:21:42      阅读:49      评论:0      收藏:0      [点我收藏+]

标签:symbol   lis   内置对象   key   ref   http   tor   dog   保存   

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 语句

标签:symbol   lis   内置对象   key   ref   http   tor   dog   保存   

原文地址:https://www.cnblogs.com/sxdjy/p/13206773.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!