【什么是闭包? 闭包产生的原因? 闭包有哪些表现形式?】

2023-10-05 22:36

本文主要是介绍【什么是闭包? 闭包产生的原因? 闭包有哪些表现形式?】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JS闭包

  • 什么是闭包?
  • 闭包产生的原因?
  • 闭包有哪些表现形式?

什么是闭包?

闭包是指一个函数可以访问并操作在其作用域之外的变量的能力。在 JavaScript 中,每当函数被创建时,就会创建一个闭包。

以下是一个简单的闭包示例:

function add(x) {return function(y) {return x + y;};
}const addThree = add(3);
console.log(addThree(5)); // 输出 8

在这个例子中,add 函数返回一个新的函数,新函数可以访问 add 函数的参数 xaddThree 是一个闭包,它存储了 add(3) 返回的函数以及 x 的值,因此调用 addThree(5) 就会返回 3 + 5 = 8

闭包在许多 JavaScript 库和框架中都得到了广泛的应用,它们可以用来实现许多高级功能,例如封装私有变量、延迟计算、事件监听和函数柯里化等。

闭包产生的原因?

闭包的产生原因是因为在函数内部定义的函数可以访问外部函数的变量和参数,即使外部函数已经执行完毕,内部函数仍然可以访问那些变量和参数。

下面是一个简单的例子:

function outerFunction() {var outerVariable = "Hello";function innerFunction() {console.log(outerVariable);}return innerFunction;
}var closure = outerFunction();
closure(); // 输出 "Hello"

在上面的代码中,outerFunction 定义了一个局部变量 outerVariable 和一个内部函数 innerFunction,并将 innerFunction 作为返回值返回。当 outerFunction 被调用时,它返回内部函数 innerFunction,然后 outerFunction 的执行结束。但是,innerFunction 仍然能够访问 outerVariable,并且在调用 closure() 时,它打印了 outerVariable 的值。这是由于 innerFunction 形成了一个闭包,将 outerVariable 保存在其内部作用域中,因此即使 outerFunction 已经执行完毕,innerFunction 仍然可以访问 outerVariable

闭包有哪些表现形式?

闭包有以下两种表现形式:

  1. 返回一个函数:当一个函数内部定义了另一个函数,并将这个内部函数作为返回值返回时,就形成了一个闭包。返回的这个函数可以访问外部函数中的变量,即使外部函数已经执行完毕并且其内部变量已经被销毁。

举例:

function outer() {var count = 0;function inner() {count++;console.log(count);}return inner;
}
var closure = outer();
closure(); // 输出1
closure(); // 输出2
closure(); // 输出3

在这个例子中,函数 outer 内部定义了一个函数 inner,并将其返回。变量 count 也定义在 outer 函数内部。
执行 outer 函数会返回函数 inner,将其赋值给变量 closure
然后调用 closure 函数,由于 closure 函数是由 outer 函数返回的 inner 函数,所以它可以访问 outer 函数内部的变量 count。因此每次调用 closure 函数都会输出一个累加的数值。

  1. 定义一个函数:在 JavaScript 中,通过定义一个函数并在该函数内部定义另一个函数,也可以形成一个闭包。这时需要将内部函数作为返回值返回,以便在外部调用。

举例:

function makeCounter() {var count = 0;function counter() {count++;console.log(count);}return counter;
}
var closure = makeCounter();
closure(); // 输出1
closure(); // 输出2
closure(); // 输出3

在这个例子中,函数 makeCounter 内部定义了函数 counter,并将其返回。变量 count 也定义在 makeCounter 函数内部。
执行 makeCounter 函数会返回函数 counter,将其赋值给变量 closure
然后调用 closure 函数,由于 closure 函数是由 makeCounter 函数返回的 counter 函数,所以它可以访问 makeCounter 函数内部的变量 count。因此每次调用 closure 函数都会输出一个累加的数值。

这篇关于【什么是闭包? 闭包产生的原因? 闭包有哪些表现形式?】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/152178

相关文章

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

IDEA中Maven Dependencies出现红色波浪线的原因及解决方法

《IDEA中MavenDependencies出现红色波浪线的原因及解决方法》在使用IntelliJIDEA开发Java项目时,尤其是基于Maven的项目,您可能会遇到MavenDependenci... 目录一、问题概述二、解决步骤2.1 检查 Maven 配置2.2 更新 Maven 项目2.3 清理本

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决