c++ map 遍历_如何使用for of 循环遍历对象

7a878f69edc18bc03863bc13cd8b639b.png
for of循环 -- 冰山工作室https://www.zhihu.com/video/1117148817958469632

使用 for-of 遍历对象是不是会轻松一点?

如何遍历对象,一般来说都会想到 for-in

let 

但是当有一些继承关系的时候,就有些麻烦了,遍历的时候会把继承的属性也遍历出来,这就得加些判断了

let 

当然多了一层缩进,有一点麻(蛋)烦(疼),所以可以省略一层,变成下面这样

for

复习就到此为止了,接下来来尝试一些其它的方式

ES6 中提供了 for-of,可以很方便的遍历数组和类数组,但是却不能遍历对象,这是为什么,与 for-in 仅仅相差一个单词,用途也是遍历,为什么却不能使用在对象上?

查资料后得知,原来 ES6 中引入了 Iterator,只有提供了 Iterator 接口的数据类型才可以使用 for-of 来循环遍历,而 ArraySetMap、某些类数组如 arguments 等数据类型都默认提供了 Iterator 接口,所以它们可以使用 for-of 来进行遍历

那么原因清楚了,该怎么解决呢?能不能为对象已经其它的一些数据类型提供 Iterator 接口呢

答案是可以的,ES6 同时提供了 Symbol.iterator 属性,只要一个数据结构有这个属性,就会被视为有 Iterator 接口,接着就是如何实现这个接口了,如下就是一个最简实现:

newObj

仔细看一下发现就会发现 Symbol.iterator 接口其实是一个 Generator 函数,那么就可以简化代码:

newObj

值得注意的是 Object.keys 碰巧解决了之前 for-in 遇到的继承问题

这样满足了我们的期望,使用 for-of 来遍历对象,但是好像哪里不对,我们遍历对象时一般都是期望同时输出 keyvalue 的,这样调整一下代码

newObj

这样返回了一个对象,似乎又很不舒服,我们能不能尝试一些解构赋值呢。。。

for

这样似乎非常完美了。。。

但回过头来看,你觉得轻松了一点么?

拓展: 在 class 中使用 Symbol.iterator

class 

冰山工作室前端来到知乎啦。本号致力于带你走进不一样的前端世界,让你在前端开发的学习路上少走弯路,快速进步。无论是你菜鸟还是大神,这里的内容都会让你眼前一亮。

技术讨论、问题解答可以在下方给我们留言,访问主站或者公众号搜索冰山工作室找到我们

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值