我对
JavaScript或Chrome控制台的行为感到困惑.有人能帮我理解吗
基本上我有以下JavaScript代码,不嵌套在任何函数或其他范围内:
var initial_array = []; function initialiseArray() { initial_array = [2,9,8,6,2,1]; } function copyToNewArray() { var copied_array = []; console.log("COPIED 1",copied_array); for (var i = 0; i < initial_array.length; i++) { var copy = initial_array[i]; copied_array.push(copy); } console.log("COPIED 2",copied_array); } initialiseArray(); copyToNewArray();
我希望COPIED 1打印[] – 因为变量尚未分配,而是打印[2,1] – 即分配后的值.
为什么?
顺便提一句,如果用行__ray_ = copy_array替换第8-11行,那么RESULTS 1的确打印为[].是否与使用.push有关?
解决方法
尝试在Chrome脚本调试器中调试问题.放上一个断点:
for (var i = 0; i < initial_array.length; i++) {
你会看到你所期望的行为.
您遇到的问题是,您正在做出错误的假设,即Chrome调试器会在异步执行console.log时立即打印该值.由于数组在后端被引用传递,当它实际上打印该值时,它现在是您看到的.