【JS重点09】JS闭包(面试重点)

本文核心目标:阅读完本文能说出什么是闭包,闭包作用以及如何利用闭包

一:闭包概览

1 闭包是什么

闭包 (closure)是一个函数以及其捆绑的周边环境状态(lexical environment词法环境)的引用的组合。换而言之,闭包让开发者可以从内部函数访问外部函数的作用域。在 JavaScript 中,闭包会随着函数的创建而被同时创建。

简言之,闭包=内部函数+外部函数变量

2 闭包作用

封闭数据,使得外部也可以访问函数内部的变量

闭包典型示例:

javascript 复制代码
<script>
    function outer() {
      let a = 100
      function inner() {
        console.log(a);
      }
      return inner
    }
    const gb = outer()
    gb()
</script>
//上面代码解析:
outer()===inner ===function inner(){}
gb() === function inner(){}
从全局作用域中使用的gb(),进而调用了函数内部变量

二:闭包应用

实现数据私有

javascript 复制代码
<script>
    function outer() {
      let a = 1
      function inner() {
        a++
        console.log(a);
      }
      return inner
    }
    const gb = outer()
    gb()
  </script>

我要记录outer函数被调用的次数,如果将let a = 1声明在全局作用域中,很容易被修改;但通过闭包方式,可以从gb()出发能够找到变量a,所以就可以实现记录,而不被垃圾回收机制清除;

同时,因为变量a是位于局部作用域中,本应运行完后清除,但是因为闭包的缘故没有实现内存回收;所以造成了内存泄漏问题

断点调试:

相关推荐
山河木马9 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
天蓝色的鱼鱼9 小时前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷10 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花10 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷10 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜10 小时前
Spring Boot 核心知识点总结
前端
lichenyang45311 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕11 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之11 小时前
页面白屏卡住排查方法
前端·javascript
用户5936087414011 小时前
Playwright 黑魔法:用 ClipboardEvent 绕过 React 富文本编辑器
前端