聊一聊js中的闭包

闭包是JavaScript中的重要概念,允许内部函数访问并保留外部函数的变量,常用于防抖节流、模块化以及实现私有变量。然而,闭包可能导致内存泄漏。文章通过示例解释了为何在for循环中使用闭包会打印8个8,并提出了解决方案。此外,还讨论了闭包在公有变量、函数颗粒化和防止全局变量污染中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

闭包是js中里面的一个重要的知识内容,我们在日常的开发中也经常会使用到闭包,比如防抖节流啊,这些都用闭包实现的,函数的颗粒化啊等等,接下来我们聊聊闭包

闭包的概念

定义:在javascript中,根据词法作用域的规则,内部函数总是可以访问外部函数中声明的变量的,当通过调用一个外部函数返回的内部函数后,即使该外部函数已经执行完毕,但是内部函数引用外部函数的变量依然保存在内存中,我们把这些变量的集合称为闭包。

接下来我们来看一段代码看看会打印什么?

function test() {
    for(var i = 0; i < 8; i++) {
        setTimeout(() => {
        console.log(i)
})
    }
}
test() // ?
//会打印8个8

为什么是打印8个8,而不是0,1,2,3,4,5,6,7呢?

因为for循环是同步执行代码,setTimeout时候异步执行代码,var声明的作用域范围在函数作用域范围内,所以js代码中,i是在test这个作用域里,所以当for循环结束后i就等于8,然后setTimeout执行打印8个8。

解决办法闭包,利用一个自执行函数产生一个闭包

function test() {
    for(var i = 0; i < 8; i++) {
        (function(i) {setTimeout(() => {
        console.log(i)
})}(i)
    }
}

闭包的缺点

闭包会导致原有的作用域链不释放,造成内存泄漏

闭包的应用

1. 可以实现公有化变量 (企业的模块开发)

2. 防抖节流,函数颗粒化,bind的实现

3. 实现属性的私有化

4. 模块化开发,防止污染全局变量

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值