【问题标题】:JavaScript For Loop with Closure Causing JSLint Warning带有闭包的 JavaScript For 循环导致 JSLint 警告
【发布时间】:2018-09-30 06:23:34
【问题描述】:

我正在编写一个 JavaScript 脚本,它使用 for 循环将 onclick 事件分配给一系列按钮。为了解决 i 范围的问题,我使用以下示例作为我的 for 循环的基础,基于 this answer。我希望我知道这种创建 for 循环的方法的名称,如果有的话。

for (var i = 0; i < 10; i++) (function(i){
    //some code
})(i);

当我通过 JSLint 和 JSHint 运行我的代码时,它会给出一个警告:“不要在循环中创建函数。”参考上面构建的两个 for 循环。我看到的关于这个警告的问题没有使用我正在使用的格式的循环,所以我不知道它们如何适用于此。

为什么会给出这个警告,还有比这更好的方法吗?此外,这种 for 循环格式是否有名称(最后一部分可以在 cmets 中回答)?如果这与其他问题有关,为什么这种格式有效?

【问题讨论】:

  • 如果我能弄清楚这个 for 循环格式的名称,我也许可以更好地写出问题标题
  • 这叫做closure

标签: javascript function for-loop jslint jshint


【解决方案1】:

这只是创建closureimmediately invoking function expressiononclick 事件将在未来某个时间发生,但到那时循环已完成执行,i 的值将更新为 i&lt;10 的最后一个值

所以在这种closureIIFE 的情况下,i 的值将被绑定并保留在范围内。

另一种方法是使用let 而不是var

for (let i = 0; i < 10; i++){
  // rest of the code
}

let 的范围总是在块级

【讨论】:

    猜你喜欢
    • 2021-10-27
    • 2017-12-23
    • 2014-02-12
    • 1970-01-01
    • 2011-05-19
    • 2015-10-24
    • 2018-09-08
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多