JS夯实基础系列之闭包

闭包

此篇为学习网络视频所做的笔记。
视频链接:Bilibili:JavaScript高级–30.闭包理解

何时产生闭包?

  1. 一个函数内部嵌套一个函数;
  2. 内部函数引用了外部函数的变量(或函数);
function aa(){
    var a = 12;
    function bb(){
        console.log(a);
    }
}
aa();

在这里插入图片描述

到底什么是闭包?

错误理解:闭包是嵌套的内部函数。

正确理解:闭包是包含被引用的外部函数变量(或函数)的对象,这个对象是在内部函数之下
在这里插入图片描述

也就是说:

  1. 闭包是一个对象。
  2. 闭包是嵌套函数下的一个对象。
  3. 这个对象包含了嵌套函数所引用的外部函数的变量(或函数)。

常见的闭包

1.将内部函数作为外部函数的返回值
function fuc1(){
    var a = 2;
    function fuc2(){
        a++;
        console.log(a);
    }
    return fuc2;
}
var f = fuc1();
f(); //3
f(); //4
2.将函数作为实参传递给另一个函数调用
function showDelay(msg,time){
    setTimeout(function(){
        alert(msg);
    },time)
}
showDelay("这也产生一个闭包!",2000)

在这里插入图片描述

闭包的作用

  1. 使函数执行完成后,函数内部的变量仍然存活于内存中(延长了局部变量的生命周期);
  2. 让函数外部可以(间接)操作(读写)函数内部的数据(变量或函数);

闭包的生命周期

视频:JavaScript高级–33.闭包的生命周期

闭包的应用

编写自定义JS模块
function myModule(){
    var aa = "Ha a Ha";
    function fn1(){
        alert(aa.toUpperCase());
    }
    function fn2(){
        alert(aa.toLowerCase());
    }
    //暴露内部成员,返回一个对象
    return {
        fn1:fn1,
        fn2:fn2
    }
}

//调用
var md = myModule();
    md.fn1();
    md.fn2();
另一种JS模块写法(匿名函数自调用)
(function(){
    var aa = "Ha a Ha";
    function fn1(){
        alert(aa.toUpperCase());
    }
    function fn2(){
        alert(aa.toLowerCase());
    }
    //给window对象挂载一个对象myModule,暴露模块内部的函数方法
    window.myModule = {
        fn1:fn1,
        fn2:fn2
    }
})();

myModule.fn1()
myModule.fn2()

关于JS模块化,貌似也是一个比较复杂的新手问题,尤其是在现在这个阶段。希望出现官方、统一且易用的解决方案吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
闭包是JavaScript一个重要且强大的概念。它指的是函数能够访问自己定义范围之外的变量,并且这些变量在函数执行完毕后仍然可以被访问到。闭包的应用场景很广泛,它可以用来创建私有变量、实现模块化、延迟执行等等。了解和掌握闭包对于理解JavaScript语言的本质,以及提高代码的可维护性和灵活性都非常有帮助。 从技术的角度来看,所有的JavaScript函数都可以被看作是闭包。因为在函数内部,它们可以访问在函数定义范围之外的变量。这也是为什么在JavaScript,函数可以在定义之后仍然可以访问外部的变量。 总结起来,闭包是JavaScript一个非常重要的概念,它能够让函数访问自己定义范围之外的变量,并且这些变量在函数执行完毕后仍然可以被访问到。了解闭包可以帮助我们更好地理解JavaScript语言的本质,并且提高代码的可维护性和灵活性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [深入理解JavaScript闭包](https://blog.csdn.net/qq_54384868/article/details/130182961)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [JavaScript深入之闭包](https://blog.csdn.net/TZOF_/article/details/117048674)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值