【发布时间】:2020-05-31 14:24:48
【问题描述】:
我正在学习 javascript,并学习 for 循环。我确定这是基本部分,但我不知道 counter 变量是如何工作的..
我正在制作战斗应用程序,这是用户点击战斗日志时执行的功能,然后它将在console.log中显示最后的日志及其索引。
函数中的战斗日志是存储用户输入嵌套数组的数组。
let lastLoggedEntry;
function printLogHandler() {
let i = 0;
for (const logEntry of battleLog) {
if ((!lastLoggedEntry && lastLoggedEntry !== 0) || lastLoggedEntry < i) {
console.log(`#${i}`);
for (const key in logEntry) {
console.log(`${key} => ${logEntry[key]}`);
}
lastLoggedEntry = i;
break;
}
i++;
}
}
我的问题是初始值设置在 for 循环之外(i = 0)。但是当用户再次点击战斗日志,再次执行该函数时,for循环如何保存last i的数据和logEntry的值? (用户第二次点击时,i = 1,logEntry = 0)
另外,它如何从第二次跳过“让 i = 0”?因为它不仅是for循环,它还执行函数,我认为javascript再次读取let i = 0,它会重置为0。(当然不会,但我想了解原因)
希望你们能帮帮我。谢谢你,
【问题讨论】:
-
您的代码将
i保存在一个全局变量中,下次调用该函数时会检查该变量。 -
嗨,是的,我首先了解 i 是全局范围。第一次时,全局范围的变量将分配给本地范围内的 i 。我明白了,但是为什么从第二次执行函数时,全局范围没有分配给本地范围一,并且本地范围可以保留上次的变量?
标签: javascript function for-loop for-of-loop