为什么在数组迭代中使用“ for…in”是JavaScript中的一个坏主意?

在JavaScript中使用for..in循环进行数组迭代是一个坏主意,因为存在以下行为-

使用普通的迭代循环-

示例

let arr = []
arr[4] = 5
for (let i = 0; i < arr.length; i ++) {
   console.log(arr[i])
}

输出结果

undefined
undefined
undefined
undefined
5

如果我们使用for in构造在此数组上进行迭代,那么我们将获得-

示例

let arr = []
arr[4] = 5
for (let i in arr) {
   console.log(arr[i])
}

输出结果

5

请注意,数组的长度为5,但这仍会迭代数组中的一个值。

发生这种情况是因为for-in语句的目的是枚举对象属性。该语句将出现在原型链中,还会枚举继承的属性,这有时是不希望的。