…的奇怪问题..循环中

Weird issue with for...in loop

本文关键字:循环 问题      更新时间:2024-04-30

这很有效:

for (var i = 0; i < this.size(); i++) {
    values.push(this.cards[i].value);
}

但这不是:

for (var card in this.cards) {
    values.push(card.value);
}

为什么?

因为在for...in循环中,变量是键,而不是值。

应该是:

for (var card in this.cards) {
    values.push(this.cards[card].value);
}
for (var card in this.cards) {
    values.push(card.value);
}

card将是索引号,而不是值。

for..in循环枚举对象的属性名,而不是属性值。应为:

for ( var key in this.cards ) {
    values.push( cards[key].value );
}

for..in的一个缺点是它还枚举继承的属性名称(当然,只有当相应的属性是可枚举的)。


另外,考虑一下:

var values = this.cards.map(function ( card ) {
    return card.value;
});

因为for (var x in y)语法在对象(键)的PROPERTIES上循环,如果它是数组,它可以是数组的成员,也可以是其他可枚举属性。

例如:

var person={fname:"John",lname:"Doe",age:25}; 
for (x in person)
{
  txt=txt + person[x];
}

将打印出所有属性(JohnDoe25),但数组的成员是元素(例如数组中包含的值)以及原型属性。考虑一下:

// Somewhere deep in your javascript library...
Array.prototype.foo = 1;
// Now you have no idea what the below code will do.
var x, a = [1,2,3,4,5];
for (x in a){
    // Now foo is a part of EVERY array and 
    // will show up here as a value of 'x'
}

x将在循环中的某个点出现为foo的值,但这几乎不是预期的。

我想说的是,除非你了解for(var x in y)的作用,否则不要使用它——不要试图成为一个刺针,只需让你免于大量的头发拉扯和抓头,我自己也曾经历过:/