js中闭包的理解

定义

闭包是指有权访问另一个函数作用域中的变量的函数。
也可以这样理解闭包的本质就是在一个函数内部创建另一个函数。
作用:

  1. 可以在函数的外部访问到函数内部的局部变量。
  2. 让这些变量始终保存在内存中,不会随着函数的结束而自动销毁。

特点:
函数嵌套函数
内部的函数可以引用外部函数的参数或者变量
参数和变量不会被垃圾回收机制回收,因为内部函数还在引用

  var aaa = function(){
             let count = 1;
            return () =>{
                return count;
            }
         }
       let b = aaa();
       console.log(b())   //count没被释放,这里return了一个匿名函数,count这个变量没被回收,被保存下来

这里的和上面的代码效果一样,只是用了函数自调用

   var aaa = (function(){
             let count = 1;
            return () =>{
                return count;
            }
         })()
       let b = aaa();
       console.log(b)

继续往下写

 var aaa = function(){
             let count = 1;
            return () =>{
                return  count++; 
            }
         }
         
       let  b = aaa();
       console.log(b())  //1
       console.log(b())  //2
       console.log(b())  //3

这里就是变量没被释放,每次调用的count值都是之前调用后的结果,这个结果任被保存在内存中,没被释放

闭包使用场景

1.setTimeout
  原生的setTimeout传递的第一个函数不能带参数,通过闭包可以实现传参效果。
2.函数防抖
  在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时。
   实现的关键就在于setTimeOut这个函数,由于还需要一个变量来保存计时,考虑维护全局纯净,可以借助闭包来实现。
3.封装私有变量

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值