为什么 for循环中 onclick() 事件的 i 值始终为循环结束后的结果?

为什么 for循环中 onclick() 事件的 i 值始终为循环结束后的结果?

for 循环中 onclick() 事件的 i 值始终为循环结束后的结果

在给定的代码中,我们使用一个 for 循环来为页面上每个带有 ".box" 类的元素添加点击事件。根据预期,当每个框被点击时,应该在控制台中打印出该框在循环中的索引。然而,代码却总是打印出 3。

要理解这个问题,我们必须了解 javascript var作用域规则。在你的代码中,var boxs 被声明为一个全局变量,这意味着它可以在脚本的任何位置访问。而 i 是在 for 循环内部使用 var 声明的,这意味着它被提升到全局作用域,但只在循环内部有效。

javascript 中,函数(包括事件处理程序)在创建时形成闭包。在这个闭包中,函数会捕获其所在作用域内声明的所有变量的引用。在你的情况下,onclick 函数捕获了 i 变量的引用。

然而,当循环执行时,i 的值会在每次迭代后更新。因此,当单击任何框时,执行的 onclick 函数会引用闭包中的 i 变量,此时 i 的值已经是循环最后执行后的值,即 3。

解决这个问题的方法是使用 let 或 const 关键字,它们可以限制变量的作用域只在声明它们的那个块或表达式范围内。在这种情况下,你可以将 for 循环内部代码改为:

for (let i = 0; i 

以上就是为什么 for循环中 onclick() 事件的 i 值始终为循环结束后的结果?的详细内容,更多请关注其它相关文章!