如何理解JS闭包

一、定义

只要在执行函数内访问外包作用域,即创建了闭包,如;

  1. 自动形成的闭包

从上图中可知,由于func3内,访问了外部作用域的a、c、e变量,进而从左侧debug中可以看出形成了三个闭包,而b、d、f没有访问,进而没有形成闭包

  1. 手动生成的闭包
var num = 10;
function add() {
    var num = 0;
    return function() {
        console.log(num++)
    }
}
var func1 = add();
var func2 = add();
func1(); // 0
func1(); // 1
func1(); // 2
func1(); // 3
func2(); // 0

二、作用

通过闭包可以让外部环境访问到函数内部的局部变量。

延长变量声明周期,让局部变量持续保存下来,不随着它的上下文环境一起销毁。

将对变量写到一个独立的空间里面,避免全局变量污染。

三、内存泄露

像上图1中这种自动形成的闭包,垃圾回收机制会进行回收

如果人为的创建的闭包,垃圾回收机制不会自动回收,需要人为的进行回收,如:将变量置为null。

四、面试真题

打印啥?

for (var i = 1; i <= 5; i++) {
    setTimeout(function () {
        console.log(i);
    }, 1000);
}

答案: 6、6、6、6、6

如何让打印1、2、3、4、5

答案1: 利用ES6的块级作用域,将var改为let

答案2: 利用闭包

for (var i = 1; i <= 5; i++) {
    (function (i) {
        setTimeout(function () {
            console.log(i); // 1、2、3、4、5
        }, 1000);
    })(i)
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值