【面试题集—No.04】for...in和for...of的区别

本文探讨了JavaScript中for...in和for...of的区别。for...in遍历对象的可枚举属性(包括继承),而不适用于数组,顺序不确定。for...of用于遍历可迭代对象,如字符串、数组、Set/Map等,确保按顺序执行。在使用for...of前,需检查对象是否为可迭代类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

💚写在前面:之前在👉获取对象属性的个数一篇提到了几个常用的Object的API,这里区别一下for...infor...of,迷迷瞪瞪的,我经常给搞混。

1.for...in 遍历 key(原理:Object.keys());for...of 遍历value

2.for...in 获取自身和继承的可枚举属性(配合hasOwnProperty(),判断是否是自身属性) ; for...of 获取自身可迭代属性的值

3.for...in用来遍历对象,不建议遍历数组(∵输出的顺序是不固定的); for...of 用来遍历字符串,数组,Set/Map结构,类数组对象,可迭代对象,Generator 对象

补充:

1.for…of循环不能循环普通的对象,对普通对象的属性遍历推荐使用for…in

2.迭代的对象的变量值是null或者undefined, for...in不执行循环体,建议在使用for...in循环之前,先检查该对象的值是不是null或者undefined

 


参考资料:

for...of - JavaScript | MDN

js中的for in 和 for of 的区别 -优快云博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值