JavaScript中for..in迴圈的陷阱
大家都知道在JavaScript中提供了兩種方式迭代物件:
(1)for 迴圈;
(2)for..in迴圈;
使用for迴圈進行迭代陣列物件,想必大家都已經司空見慣了。但是,使用for.. in迴圈時,大家可要注意了,為什麼這麼說呢?大家聽我娓娓道來....
javascript提供了一種特殊的迴圈(也就是for .. in迴圈),用來迭代物件的屬性或陣列的每個元素,for...in迴圈中的迴圈計數器是字串,而不是數字。它包含當前屬性的名稱或當前陣列元素的索引。
案例一:
//使用for..in迴圈遍歷物件屬性
varperson={
name: "Admin",
age: 21,
address:"shandong"
};
for(vari in person){
console.log(i);
}
執行結果為:
name
age
address
當遍歷一個物件的時候,變數 i 也就是迴圈計數器 為 物件的屬性名
//使用for..in迴圈遍歷陣列
vararray = ["admin","manager","db"]
for(vari in array){
console.log(i);
}
執行結果:
0
1
2
當遍歷一個數組的時候,變數 i 也就是迴圈計數器 為 當前陣列元素的索引
案例二:
但是,現在看來for .. in迴圈還挺好用啊,不過,別高興太早,看看下面的例子:
var array =["admin","manager","db"];
//給Array的原型新增一個name屬性
Array.prototype.name= "zhangsan";
for(var i in array){
alert(array[i]);
}
執行結果:
admin
manager
db
zhangsan
咦,奇觀了,怎麼平白無故的冒出來一個zhangsan
現在,再看看使用 for迴圈會怎樣?
vararray = ["admin","manager","db"];
//給Array的原型新增一個name屬性
Array.prototype.name = "zhangsan";
for(var i =0 ; i<array.length; i++){
alert(array[i]);
};
執行結果:
admin
manager
db
哦, 現在明白了,for..in迴圈會把某個型別的原型(prototype)中方法與屬性給遍歷出來,所以這可能會導致程式碼中出現意外的錯誤。為了避免這個問題,我們可以使用物件的hasOwnProperty()方法來避免這個問題,如果物件的屬性或方法是非繼承的,那麼hasOwnProperty() 方法返回true。即這裡的檢查不涉及從其他物件繼承的屬性和方法,只會檢查在特定物件自身中直接建立的屬性。
案例三:
vararray = ["admin","manager","db"];
Array.prototype.name= "zhangshan";
for(vari in array){
//如果不是該物件自身直接建立的屬性(也就是該屬//性是原型中的屬性),則跳過顯示
if(!array.hasOwnProperty(i)){
continue;
}
alert(array[i]);
}
執行結果:
admin
manager
db
一切又完好如初,哎,不知道,同志們看完有什麼感受,是不是有種“撥開雲霧見晴天”的感覺啊,呵呵