如何理解JS闭包


prtyaa
prtyaa 2023-12-26 18:56:33 53250
分类专栏: 资讯

一、定义

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

1. 自动形成的闭包

 

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

2. 手动生成的闭包

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)
}

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=31069
赞同 0
评论 0 条
prtyaaL2
粉丝 1 发表 2553 + 关注 私信
上周热门
如何使用 StarRocks 管理和优化数据湖中的数据?  2959
【软件正版化】软件正版化工作要点  2878
统信UOS试玩黑神话:悟空  2843
信刻光盘安全隔离与信息交换系统  2737
镜舟科技与中启乘数科技达成战略合作,共筑数据服务新生态  1270
grub引导程序无法找到指定设备和分区  1235
华为全联接大会2024丨软通动力分论坛精彩议程抢先看!  165
点击报名 | 京东2025校招进校行程预告  164
2024海洋能源产业融合发展论坛暨博览会同期活动-海洋能源与数字化智能化论坛成功举办  163
华为纯血鸿蒙正式版9月底见!但Mate 70的内情还得接着挖...  159
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

加入交流群

请使用微信扫一扫!