- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
很简单,我想知道为什么对 arr0 的调用似乎拖入了 i 的值,而不是存储在函数中该位置的值。
<script>
var arr = [];
for(var i = 0; i < 3; i++) {
//Assign anonymous functions to the array in positions 0 to 2
arr[i] = function() { console.log("function " + i); }
}
for(var i = 0; i < 3; i++) {
//The output for these function calls is correct!
arr[i]();
}
//Here I expected to output: function 0, but instead outputs: function 3 WTF!
arr[0] ();
</script>
这是输出:
function 0
function 1
function 2
function 3
对于最后一次调用,即:arr[ 0 ] ();我预计输出是“function 0”,但令人惊讶的是它不是......可以请有人解释一下原因吗?
提前致谢!
最佳答案
嗯,这是一个混合体......
您正在使用放置在全局范围内的相同 i
变量(尽管在第二个循环中“重新定义”了它,但它仍然是相同的 i
)
因此,在第二个循环中,每次迭代都会更改该 global i
的值,从而导致
function 0
function 1
function 2
function 3
输出。
顺便说一句,如果您在第二个循环中使用k
,这绝对不是预期的结果:
<script>
var arr = [];
for(var i = 0; i < 3; i++) {
//Assign anonymous functions to the array in positions 0 to 2
arr[i] = function() { console.log("function " + i); }
}
for(var k = 0; k < 3; k++) {
//The output for these function calls is correct!
arr[k]();
}
//Here I expected to output: function 0, but instead outputs: function 3 WTF!
arr[0] ();
</script>
这会产生:
function 3
function 3
function 3
function 3
这就是上面链接(评论中)提到的臭名昭著的循环问题。
原因是在第一个循环中定义的函数(顺便说一句,在一般情况下您应该尽量避免)“关闭”与其定义相同范围内的变量 - i
在这种情况下。这意味着以后每当 i
的值发生更改时,它都会反射(reflect)在该函数中。
最后一个示例显示了它的实际效果 - i
由 first for
循环更改,因此当循环完成时 - 它的值是3
。您定义的所有函数现在都具有相同的i
值 - 3
。
要使输出像这样:
function 0
function 1
function 2
function 0
你可以做到这一点(并不是说它那么好,结构明智):
var arr = [];
for(var i = 0; i < 3; i++) {
//Assign anonymous functions to the array in positions 0 to 2
arr[i] = (function(index){ return function() { console.log("function " + index); };}(i));
}
for(var k = 0; k < 3; k++) {
//The output for these function calls is correct!
arr[k]();
}
//Here I expected to output: function 0, but instead outputs: function 3 WTF!
arr[0] ();
这会产生所需的结果。
在这里,您定义一个匿名函数:
(函数(索引){ ... }(i))
立即以 i
作为参数调用。该参数在函数体中被称为 index
(并不是说它很重要,即使您仍然将其称为 i
- 它会起作用,因为“内部”i
会遮蔽“外部”的)。
该函数返回一个在 index
上具有不同闭包的函数,这并不重要,因为在立即调用的函数存在后 index
不可用。
另一种方法是使用某种迭代器 - map
,如果支持的话,就可以了。
关于javascript - 有人可以向我解释一下这个匿名函数数组的作用域是如何工作的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20557817/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!