JavaScript高级:闭包

1 概念

一个函数对周围状态的引用,捆绑在一起,内层函数中可以访问到外层函数的作用域。

简单理解:闭包 = 内层函数 + 外层函数的变量

先看个简单的代码:

function outer() {
      let a = 1
      function inner() {
          console.log(a)
       }
}
outer()

2 闭包的作用

封装数据,提供给操作,外部也可以访问函数内部的变量

3 闭包的基本格式

function outer() {
      let a = 1
      function inner() {
          console.log(a)
      }
      return inner
}
const fn = outer()
fn()

4 闭包的应用

可以实现数据的私有化

1. 案例:比如我们需要统计函数调用的次数时,函数调用一次,次数就 ++


        let count = 0;
        function fn() {
            count++
            console.log(`函数被调用了${count}次`)
        }

        fn()  // 1次
        fn()  // 2次


但是现在count属于全局变量,很容易被篡改, 比如现在,我将count篡改为100


所以上述定义为全局变量,就很容易被修改,接下来就可以使用闭包来解决容易被篡改的问题了。

2. 使用闭包实现数据私有化:

        function count() {
            let count = 0
            function fn() {
                count++
                console.log(`函数被调用了${count}次`)
            }
            return fn
        }
        const fn = count()
        fn()  // 1次
        fn()  // 2次


这时,当我们每调用一次函数时,都是从下面的位置开始执行的,属于函数内部,不会受到外部的影响。

5 闭包存在的问题

会产生内存泄漏

比如以下示例代码:

        function count() {
            let count = 0
            function fn() {
                count++
                console.log(`函数被调用了${count}次`)
            }
            return fn
        }
        const fn = count()
        fn()  // 1次
        fn()  // 2次

采用标记清除法来判断上述变量count是否能够被回收

所以当这段代码执行完时,count应该是被回收的,但是没有被回收,这种就会造成内存泄漏。

想要了解js的垃圾回收机制的可以参考http://t.csdnimg.cn/TGyFE

  • 14
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是小蟹呀^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值