我传入一个要解析的错误消息数组。一个输入示例是:
"An item with this x Id already exists.
An item with this y id already exists.
An item with this barcode already exists.
"也就是说,字符串实际上是上面的每一行都由一个\n分隔,最后一个\n在末尾。
function( msg )
{
alert( "\"" + msg + "\"" );
var aLines = msg.split( /\r?\n+/ );
for ( var i in aLines )
{
if ( !aLines[i] ) { alert( "Error!" ); continue; }
alert( i + ": \"" + aLines[i] + "\"" );
}
}我把它分成几行,然后遍历这些行。在索引3处,没有行和第一个条件触发器。这不应该是一个空行吗?例如"“
然后循环实际上又将一个元素转到4,并显示一个函数的内容。
这就是我得到的-5个警报:
0: "An item with this x Id already exists."
1: "An item with this y id already exists."
2: "An item with this barcode already exists."
Error!最后一个最奇怪的是:
hasObject: "function(o) {
var l = this.length + 1;
... more lines ...
}我不明白这里发生了什么。为什么它要迭代一个以上的元素?为什么最后一个元素是函数?偏移量3不应该是空字符串吗?那就是我不应该警告“错误!”这里。
发布于 2012-10-20 03:13:17
发布于 2012-10-20 03:16:47
正如jbabey所说,在Javascript中使用for .. in循环是危险和不确定的(随机顺序--有时)。在解析关联数组中的对象时,最常用的就是它。但是,如果您坚持保留for .. in,请使用if块包装for的内部,如下所示:
for (var i in aLines)
{
if(aLines.hasOwnProperty(i))
{
// ... Do stuff here
}
}否则,只需将其更改为经典的增量for循环即可消除该错误:
for (var i = 0; i < aLines.length; i++)
{
if ( !aLines[i] ) { alert( "Error!" ); continue; }
alert( i + ": \"" + aLines[i] + "\"" );
}发布于 2012-10-20 03:21:53
您应该对数组使用常规的for循环,因为for-in还将返回Array对象中的所有其他属性键。这就是为什么你会看到"hasObject“(在我的浏览器中,我看到了更多):因为你的数组有函数"hasObject",所以当你枚举所有数组的属性时,就会出现这个问题。
正确的for循环:
for ( var i = 0, ii = aLines.length; i<ii; i++ )
{
if ( !aLines[i] ) { alert( "Error!" ); continue; }
alert( i + ": \"" + aLines[i] + "\"" );
}下面是将for-in循环替换为for循环的代码,它按预期工作:
http://jsfiddle.net/SamFent/4rzTh/
https://stackoverflow.com/questions/12980860
复制相似问题