在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语句的目的是枚举对象属性。该语句将出现在原型链中,还会枚举继承的属性,这有时是不希望的。