首页技术文章正文

什么是闭包函数?如何实现?

更新时间:2021-10-08 来源:黑马程序员 浏览量:

IT培训班

什么是闭包函数?

在JavaSeript中,内嵌函数可以访问定义在外层函数中的所有变量和函数,并包括其外层函数能访问的所有变量和函数。但是在函数外部则不能访问函数的内部变量和嵌套函数。

此时就可以使用“闭包”来实现。

所谓“闭包”指的就是有权访问另一个函数作用域内变量(局部变量)的函数。 它最主要的用途是以下两点。

1.可以在函数外部读取函数内部的变量。

2.可以让变量的值始终保持在内存中。

需要注意的是,由于闭包会使得函数中的变量一直被保存在内存中,内存消耗很大,所以滥用闭包可能会降低程序的处理速度,造成内存消耗等问题。

闭包函数的实现

常见的闭包创建方式就是在一个函数内部创建另一个函数,通过另一个函数访问这个函数的局部变量。为了让大家更加清楚闭包函数的实现,下面我们通过代码进行演示。

function fn() {
    var times = 0;
    var c = function() {
        return ++times;
    };
    return c;
}
var count = fn();   //保存fn()返回的函数,此时count就是一个闭包
//访问测试
console.log(count());	//输出结果: 1
console.log(count());	//输出结果: 2
console.log(count());	//输出结果: 3
console.log(count());	//输出结果: 4
console.log(count());	//输出结果: 5

上述第3 ~ 5行代码,利用闭包函数实现了在全局作用域中访问局部变量times,并让变量的值始终存储在内存中。第8行代码调用fn()函数后,接下来将匿名函数的引用返回给count变量,且匿名函数中使用了局部变量times,因此,局部变量times不会在fn()函数执行完成后被JavaScript回收,依然保存在内存中。

1633682066358_闭包.jpg

运行效果



猜你喜欢:

JavaScript for循环语句操作

JavaScript代码写在哪里?

javascript开发工具有哪些?

JavaScript有哪三部分组成?

黑马程序员HTML&JS+前端高手班

分享到:
在线咨询 我要报名
和我们在线交谈!