JavaScript中的闭包

本文深入浅出地介绍了JavaScript中的闭包概念,通过示例代码详细解释了闭包的工作原理及其应用场景,同时探讨了闭包的优缺点。

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

  • 什么是JS闭包

           官方解释:闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。

 

           恐怕没几个人能看懂这么饶的话,说得通俗一些,实际上所有的function都是闭包,但是嵌套使用function才能真正发挥闭包的作用,这也是我们大多数时候提到的”闭包“。

          先看示例:

 

function aaa(){
var i=1;//aaa内部变量i
function bbb(){alert(++i);}//bbb函数执行++i并弹框
return bbb;
}
var ccc=aaa();//将函数aaa赋予变量ccc
ccc();//执行ccc

 

  执行过程:将aaa赋予变量ccc=>执行ccc=>初始化aaa内部变量i=>执行函数bbb=>执行++i=>弹框

  执行结果:

 

           注意这端JS的两个特点:

            i:aaa()内return了bbb()函数

            ii:bbb()函数嵌套在aaa()内部

 

           这个就是闭包。

           使function外部变量可以调用自身内部变量时,便是闭包。

 

 

  • 闭包有什么用

           闭包的作用有两个:

 

           i:可以使外部方便使用某个function内部变量

           ii:使闭包内部变量不会被JS垃圾回收机制GC回收掉。

 

  • 闭包的隐含缺陷

           上面提到闭包的作用有一条是“使闭包的function内部变量不被GC回收”,这就可能导致内存使用过大,所以在使用完之后及时清理不使用的闭包内的变量。

  • 什么时候用闭包

           当需要保持某个function内部变量一直存在时,使用闭包。

 

            比如:

 

function userManager(){

     var userName;

     this.registerUser=function(name){
          userName=name;
     }
      
     this.showUserName=function(){
      return userName;
      }


}


           一旦登记(registerUser)了用户,用户就存在于内存当中,我要使用他时,只要用userManger的showUserName函数就可以随时随地获取数据。

 

 

  • JS垃圾回收机制

             刚刚提到垃圾回收机制,那什么时候回收内存:

             在JS中,如果一个对象不再被引用,那这个对象就会被GC回收。若两个对象相互引用,而不被第三个对象引用,那这两个相互引用的对象也会被回收。

  • 闭包重要性

            闭包在JS当中使用频繁,可以说要写出较高水平的JS都需要闭包。

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值