一讲到闭包,通常就是类似下面的例子——
有的人甚至说,只有从一个函数里返回另一个函数才能算是闭包。
但是根据《Professional Javascript for Web Developers》的定义——
Closures are functions that have access to variables from another function’s scope. This is often accomplished by creating a function inside a function.
犀牛书——
Technically, all JavaScript functions are closures: they are objects, and they have a scope
chain associated with them.
那下面这段代码算不算产生了闭包?
1
2
3
4
5
6
7
8
9
|
var
generateClosure =
function
() {
var
count = 0;
var
get =
function
() {
count ++;
return
count;
};
return
get;
};
var
counter = generateClosure();
|
有的人甚至说,只有从一个函数里返回另一个函数才能算是闭包。
但是根据《Professional Javascript for Web Developers》的定义——
Closures are functions that have access to variables from another function’s scope. This is often accomplished by creating a function inside a function.
犀牛书——
Technically, all JavaScript functions are closures: they are objects, and they have a scope
chain associated with them.
那下面这段代码算不算产生了闭包?
1
2
3
4
5
6
7
8
9
|
var
generateClosure =
function
() {
var
count = 0;
var
get =
function
() {
console.log(count);
};
get();
};
generateClosure();
|
不是
簡單點說 generateClosure 執行過程中,get被執行,雖然它引用了 generateClosure 中的 count,但在 generateClosure 執行完之前, get也己經執行完了,所以整個過程運行完以后,所有局部變量都沒有被當前還存在的其它變量(對象)引用,己經被系統銷毀了。
簡單點說 generateClosure 執行過程中,get被執行,雖然它引用了 generateClosure 中的 count,但在 generateClosure 執行完之前, get也己經執行完了,所以整個過程運行完以后,所有局部變量都沒有被當前還存在的其它變量(對象)引用,己經被系統銷毀了。
这个不算闭包。
闭包比较关键的地方在于函数A执行完毕后,函数里的变量或参数并没有被回收而被其他函数B(常见的情况就是B在A内声明或定义)引用着。
你的例子,
第一个:generateClosure执行完后,它返回的函数(也就是counter)还引用着它的变量count,所以是闭包。
第二个:generateClosure执行完后,它没有返回函数,它的外面也没有其他函数引用着它的变量,它的变量被回收,所以不是闭包
闭包比较关键的地方在于函数A执行完毕后,函数里的变量或参数并没有被回收而被其他函数B(常见的情况就是B在A内声明或定义)引用着。
你的例子,
第一个:generateClosure执行完后,它返回的函数(也就是counter)还引用着它的变量count,所以是闭包。
第二个:generateClosure执行完后,它没有返回函数,它的外面也没有其他函数引用着它的变量,它的变量被回收,所以不是闭包