引用一个stackoverflow的提问
个人觉得总结的比较好的两句话: "An anonymous function is just a function that has no name; nothing more. A closure is a function that captures the state of the surrounding environment."
A:
Hi,
I have been unable to find a definition that clearly explains the differences between a closure and an anonymous function.
Most references I have seen clearly specify that they are distinct "things" yet I can't seem to get my head around why.
Could someone please simplify it for me? What are the specific differences between these two language features? Which one is more appropriate in what scenarios?
Q:
An anonymous function is just a function that has no name; nothing more. A closure is a function that captures the state of the surrounding environment.
An anonymous function does not necessarily need to create a closure, and a closure is not created only for anonymous functions.
Consider this hypothetical counter-example. Consider a language Foo which does not support closures but supports anonymous functions. This language may either not compile or throw an error for the code below because "greeting" is not defined in the scope of the inner function. The fact that it is anonymous is irrelevant.
function outer() {
var greeting = "hello ";
(function(name) {
alert(greeting + name);
})("John Doe");
}
Let's consider an actual language now that does support closures - JavaScript. Taking the same example as above, but naming the inner function this time gives:
function outer() {
var greeting = "hello ";
(function inner(name) {
alert(greeting + name);
})("John Doe");
}
Although the inner function is not anonymous anymore, it still captures state from the surrounding environment.
Closures provide much needed convenience, as otherwise we would be passing every single dependency of the function as an argument.
function outer() {
var greeting = "hello ";
(function(name, greeting) {
alert(greeting + name);
})("John Doe", greeting);
}
原文地址: http://stackoverflow.com/ques...
另外,附上MDN中对闭包的讲解:
Closures - JavaScript(English): http://developer.mozilla.org/...
闭包 - JavaScript(中文): http://developer.mozilla.org/...
Dmitry Soshnikov对于闭包的简要概括
Closures in ECMAScript are directly related with the [[Scope]] property of functions. As it has been noted, [[Scope]] is saved at function creation and exists until the function object is destroyed. Actually, a closure is exactly a combination of a function code and its [[Scope]] property. Thus, [[Scope]] contains that lexical environment (the parent variable object) in which function is created. Variables from higher contexts at the further function activation will be searched in this lexical (statically saved at creation) chain of variable objects.
原文
原文地址:匿名函数和闭包(来自stackoverflow)
文章作者:zdying
版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证) 转载请注明出处
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。