浅谈 for in 与 for of 的区别

最近做项目,项目中有些地方使用到 for in 循环,遇到一个头痛的问题,遍历的时候总会多出一个方法,找了很久(头痛),最后发现我在 Array 原型上添加了方法,自己测试了几遍,终于找出问题的关键点:

// 原型添加方法contains 和属性 subTitle
Array.prototype.contains = function() { return null } 
Array.prototype.subTitle= 'Flutter'

let arr = ['Vue', 'React', 'Angular', 'Node']
for (let i in arr) {
	console.log(arr[i])
}

打印结果,发现遍历了原型的方法和属性
在这里插入图片描述
解决方法:

①:利用JS方法 hasOwnProperty()过滤对象的属性

for (let i in arr) {
	if (arr.hasOwnProperty(i)){
	  console.log(arr[i])
	}
}

在这里插入图片描述
虽然解决了问题,但是 for in 遍历数组会遍历原型的方法属性,推荐使用 for in 遍历对象,同 Object.keys()

let obj = {name:'小明', age:20}
for (let i in obj) {
  console.log(obj[i])
}

let result = Object.keys(obj) // ['name','age']
console.log(result.map(item => obj[item]))

在这里插入图片描述
②:第二个方法,那就是利用我们的 for of

for of 与 for in 不同 他不会遍历原型的方法和属性

Array.prototype.contains = function() { return null }
Array.prototype.subTitle= 'Flutter'

let arr = ['Vue', 'React', 'Angular', 'Node']
for (let i of arr) {
 console.log(i)
}

在这里插入图片描述
for of 会遍历拥有迭代器对象的集合,调用 Symbol.iterator 生成一个迭代器对象。它不能遍历对象,因为没有迭代器对象,会报以下错误
在这里插入图片描述
正确姿势,借助 Object.keys() 枚举对象key

let obj = {name:'小明', age:20}
for (let i of Object.keys(obj)) {
  console.log(obj[i]) // 小明 20
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端小小白zyw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值