print?Array.prototype.Contains = function (str) {
if (!str) return false;
for (var i = 0;
i < this.length; i++) {
if (this[i] == str) { return true; } }
return false; }
var tmp = new Array();
tmp.push("1");
tmp.push("2");
tmp.push("3"); alert("遍曆屬性");
for ( var i in tmp ) {
alert(tmp[i]); } alert("遍曆數組");
for ( var i=0;i<tmp.length;i++ ) {
alert(tmp[i]); } Array.prototype.Contains = function (str) {
if (!str)
return false;
for (var i = 0; i < this.length; i++) {
if (this[i] == str) {
return true;
}
}
return false;
}
var tmp = new Array();
tmp.push("1");
tmp.push("2");
tmp.push("3");
alert("遍曆屬性");
for ( var i in tmp ) {
alert(tmp[i]);
}
alert("遍曆數組");
for ( var i=0;i<tmp.length;i++ ) {
alert(tmp[i]);
}如果是非IE8瀏覽器,例如(IE7、IE9、Chrome、FF,僅測試這幾種)
通過屬性和數組遍曆,其結果是一樣的。
但對於IE8,結果會有一點小小的差異,在IE8下會把原型鏈擴充方法當做一個屬性輸出,大家可以測試一下。
之所以發現這個差異,也是因為解決了一個詭異的bug,有同事在代碼裡面使用for ( var i in tmp )這種方式來遍曆數組的每個元素,如果正好對Array定義了原型鏈方法,則會發生這個問題。
所以建議:如果遍曆數組元素,還是應該採用標準的寫法 for ( var i=0;i<tmp.length;i++ )。