11

我有以下代码:

console.log("start");
for(var i = 0; i < array.length; i++){
    console.log(i + " = " + array[i]);
}
console.log(array);
console.log("end");

这给了我以下输出:

[16:34:41.171] start
[16:34:41.171] 0 = 0
[16:34:41.172] 1 = 168
[16:34:41.172] 2 = 171
[16:34:41.172] [0, 168, 171, 139]
[16:34:41.172] end

也就是说,它在迭代数组时不显示 139 元素,但 console.log 在输出整个数组时会打印它。为什么?(<--问题)

我稍后会修改数组,console.log 是否以某种方式延迟到我更改数组之后?请注意,更改语句的顺序,consoel.log(array)直接放在开头不会改变结果(仍然是不同的输出)。

我正在使用 Firefox 20.0

4

1 回答 1

15

更新:如果您想查看此行为,请将代码复制并粘贴到控制台中并执行。然后关闭开发人员工具并再次打开,显然指针的事情只有在后台执行代码时才会发生(当你重新打开控制台时会发生这种情况)。

Console.log 输出的对象,是一个指针,没有真正的值。这意味着如果对象稍后发生更改,console.log 对象将被更新。尝试:

console.log("start");
var array = [1];
for(var i = 0; i < array.length; i++){
    console.log(i + " = " + array[i]);
}
console.log(array);
console.log("end");
array.push(9999);// you will see the 9999 in the console no matter it was added after the output.

为了防止指针问题,试试这个:console.log(array.join()); 因为稍后在您的应用程序的某个时刻,您将添加 139 值。

于 2013-05-10T14:53:13.380 回答