闭包是什么
阮一峰大神定义:
闭包就是能够读取其他函数内部变量的函数。
由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。
所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
或者
闭包是指有权访问另外一个函数作用域中的变量的函数
闭包的产生时间
例:
function fn1() {
var a = 2;
var b='abc';
function fn2() { //执行函数定义就会产生闭包(不用调用内部函数)
console.log(a);
}
fn2();
}
fn1();
使用Chrome检索:
对第2行检索检索,可以发现,在未执行调用fn2
函数时,就已经产生了闭包
对第5行进行检索,可以发现在函数fn2
中,a有已获取到值
如何产生闭包
例子:
1.将嵌套函数作为函数返回值
function fn1() {
// 此时闭包就已经产生了
var a = 2;
function fn2() {
a++;
console.log(a)
}
return fn2;
}
var f = fn1();
f(); // 3
f(); // 4
f = null// 闭包死亡
2.将嵌套函数作为实参传递给外层函数调用
function foo() {
var a = 2;
function bar() {
// 执行RHS查询
console.log(a); // 2
}
fbi(bar);
}
function fbi(fn) {
fn(); // 这就是闭包
}
foo();
使用回调函数,就是使用闭包
function wait() {
setTimeout(function timer() {
console.log('我是涵盖wait函数作用域的闭包');
}, 1000);
}
wait();
这里的setTimeout其实是window的方法,故声明在全局作用域,它(setTimeout方法)会在函数内部去调用传入的第一个参数(timer函数)的引用,所以这也是一个闭包!不要不认识他哦(可以同如何产生闭包的第二种情况做类比)
闭包的作用
- 延长了局部变量的生命周期
- 让函数外部可以操作(读写)到函数内部的数据(变量/函数)