JavaScript闭包

闭包是什么

阮一峰大神定义:

闭包就是能够读取其他函数内部变量的函数。

由于在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函数)的引用,所以这也是一个闭包!不要不认识他哦(可以同如何产生闭包的第二种情况做类比)

闭包的作用

  • 延长了局部变量的生命周期
  • 让函数外部可以操作(读写)到函数内部的数据(变量/函数)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值