【JavaScript进阶学习】关于闭包

闭包

  1. 利用了作用域的嵌套,将原本的局部变量,进化成私有变量,的环境,称为闭包
    • 闭包将原本要删除的变量,临时保存起来,可以继续再次使用
  2. 闭包触发了计算机的垃圾回收机制(硬盘)
    • 内存:程序结束(功能结束,函数结束)即删除
    • 硬盘:不需要使用的文件或数据,先保存在回收站(临时空间)中,如需再次使用,可以从回收站中获取
  3. 函数的定义,函数的执行
    • 函数的定义作用域:函数定义时所处的作用域
    • 函数的执行作用域:函数执行时所处的作用域
    • 规定:函数在执行时,可以获取到自身定义作用域中的数据或变量
    // a的作用域是局部
    function fn() {
        let a = 10;
        a++;
        console.log(a);
    }
    fn(); //11
    fn(); //11
    fn(); //11

    //利用了作用域的嵌套,将原本的局部变量,进化成私有变量的环境,成为闭包
    ; let fn = (
        function () {
            let a = 10;
            return function fn() {
                a++;
                console.log(a);
            }
        }
    )();
    fn();   //11
    fn();   //12
    fn();   //13
  1. 特点:
    • 作用域内外部沟通的桥梁
    • 可以在作用域外部操作作用域内部的数据
    • 闭包浪费性能,占用内存
    • 闭包会造成内存泄漏
  2. 场景
    • 循环中的事件内,无法获取循环每次的计数器
    • 给无法传参的内置函数的回调函数传参
      • 给setTimeout的回调函数传参
    //给无法穿参的回调函数传参
    // setTimeout的第一个参数,本来应该传一个函数
    // setTimeout的第一个参数,传了一个undefined
    // setTimeout的第一个参数,传入一个闭包函数

    setTimeout(fn('world'), 2000)
    function fn(a) {
        return function () {
            console.log(a);
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

草率怪199888

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

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

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

打赏作者

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

抵扣说明:

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

余额充值