循环/闭包中的JavaScript函数
JavaScript function within loop / closure
我是JavaScript的新手,正在尝试理解这段代码的行为,它试图将唯一的onclick
处理程序分配给数组myElements[]
:中的不同DOM元素
(function handleClicks(){
for (var i = 0; i < 100; ++i) {
myElements[i].onclick = function() {
alert( 'You clicked on: ' + i );
};
})();
我的理解是,每次点击DOM元素时,浏览器都应该提醒"您点击了100",因为一旦函数完成,JavaScript就会使用i
的值
我有两个问题:
如果
i
只在函数handleClicks()
内有作用域,那么一旦函数完成,浏览器如何访问i
——i
肯定不存在了?我通过在数组中放入两个HTML元素来尝试此代码
var myElements = []; myElements.push( document.getElementById('1'); myElements.push( document.getElementById('2');
http://jsfiddle.net/branmong/fS7qE/
但当程序运行时,它会为每个点击的元素发出"你点击了:2"的警报。
为什么它不提醒"你点击了:100"。因为一旦函数完成运行,这肯定是i
的值吗?
"如果
i
只在函数handleClicks()
内有作用域,那么一旦函数完成,浏览器如何访问i
?i
肯定不存在了?"
i
变量位于封装范围(handleClicks
函数)中。当一个函数被创建时,它会在函数的生命周期中携带其原始的变量范围。这被称为闭包。
因此,循环中创建的所有处理程序函数都引用了handleClicks
中存在的相同i
变量。这使i
保持活力。当您销毁处理程序时,i
将能够被垃圾收集。
第二个代码示例在2
处停止,因为访问undefined
上的属性时会得到TypeError。这将停止代码的执行。
这是因为myElements数组中只有两个元素。因此,循环只执行uptl 2,然后出错。如果您添加了5个元素,它将显示5个,如果您添加100,则显示100。
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 正在全局范围中查找JavaScript函数
- 如何将输入(type=text)从html表单传递到javascript函数
- 如何调用这个匿名 JavaScript 函数
- 通过Ajax将JavaScript函数传递给PHP文件
- 在javascript函数中设置全局变量
- 如何在执行此特定onclick事件时执行JavaScript函数
- 使用javascript函数在页面初始化后加载jquery
- javascript函数同步
- 如何将一个JavaScript函数回调为多个函数
- 在javascript函数中使用php变量
- 代码背后调用一个JavaScript函数的按钮点击-C#
- 将JavaScript函数与HTML分离
- 组合两个javascript函数
- 在 Java 中的 JavaScript 函数中插入 Wicket 值
- javascript函数内部的代码用逗号而不是分号分隔
- href属性内的javascript函数
- 使用html表单中的参数调用JavaScript函数
- 分析Javascript函数中的多个对象
- javascript函数的:和=之间的区别