摘要:闭包闭包的概念由于在语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成定义在一个函数内部的函数,或者能够读取其他函数内部变量的函数。
闭包
1. 闭包的概念:
由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数",或者“能够读取其他函数内部变量的函数”。
所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
2. 闭包的用途:
闭包最大用处有两个:
可以读取函数内部的变量;
让这些变量的值始终保持在内存中。
function outer() { var n = 9; adding = function() { n++; } function inner() { alert(n); } return inner; } var result = outer(); result(); // 9 adding(); result(); // 10
分析:在这段代码中,result实际上就是闭包inner函数。它一共运行了两次,第一次的值是9,第二次的值是10。这证明了,函数outer中的局部变量n一直保存在内存中,并没有在outer调用后被自动清除。
为什么会这样呢?原因就在于outer是inner的父函数,而inner被赋给了一个全局变量result,这导致inner始终在内存中,而inner的存在依赖于outer,因此outer也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage collection)回收。
这段代码中另一个值得注意的地方,就是"adding=function(){n++;}"这一行,首先在adding前面没有使用var关键字,因此adding是一个全局变量,而不是局部变量。其次,adding的值是一个匿名函数(anonymous function),而这个匿名函数本身也是一个闭包,所以adding相当于是一个setter,可以在函数外部对函数内部的局部变量进行操作。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/84000.html
摘要:如何在初学就理解闭包你需要接着读下去。这样定义闭包是函数和声明该函数的词法环境的组合。小结闭包在中随处可见。闭包是中的精华部分,理解它需要具备一定的作用域执行栈的知识。 这是本系列的第 4 篇文章。 作为 JS 初学者,第一次接触闭包的概念是因为写出了类似下面的代码: for (var i = 0; i < helpText.length; i++) { var item = he...
摘要:当初看这个解释有点懵逼,理解成闭包就是函数中的函数了。里的闭包最近不满足于只干前端的活,开始用起了。里的闭包最近在学习语言,让我们来看一下语言里的闭包。在中,闭包特指将函数作为值返回的情况,被返回的函数引用了生成它的母函数中的变量。 本人开始接触编程是从js开始的,当时网上很多人说闭包是难点,各种地方对闭包的解释也是千奇百怪。如今开始接触js以外的各种编程语言,发现不光是js,php、...
摘要:当初看这个解释有点懵逼,理解成闭包就是函数中的函数了。里的闭包最近不满足于只干前端的活,开始用起了。里的闭包最近在学习语言,让我们来看一下语言里的闭包。在中,闭包特指将函数作为值返回的情况,被返回的函数引用了生成它的母函数中的变量。 本人开始接触编程是从js开始的,当时网上很多人说闭包是难点,各种地方对闭包的解释也是千奇百怪。如今开始接触js以外的各种编程语言,发现不光是js,php、...
摘要:闭包在我理解是一种比较抽象的东西。所以我写了一篇博文来方便自己理解闭包。那么现在我们可以解释一下闭包的第一个定义在计算机科学中,闭包是引用了自由变量的函数。循环中创建闭包在我们使用的关键字之前,闭包的一个常见问题就出现在循环中创建闭包。 零. 前言 从我开始接触前端时就听说过闭包,但是一直不理解闭包究竟是什么。上网看了各种博客,大家对闭包的说法不一。闭包在我理解是一种比较抽象的东西。所...
摘要:但是闭包也不是什么复杂到不可理解的东西,简而言之,闭包就是闭包就是函数的局部变量集合,只是这些局部变量在函数返回后会继续存在。可惜的是,并没有提供相关的成员和方法来访问闭包中的局部变量。 (收藏自 技术狂) 前言:还是一篇入门文章。Javascript中有几个非常重要的语言特性——对象、原型继承、闭包。其中闭包 对于那些使用传统静态语言C/C++的程序员来说是一个新的语言特性。本文将...
阅读 1297·2021-11-22 09:34
阅读 2162·2021-10-08 10:18
阅读 1724·2021-09-29 09:35
阅读 2453·2019-08-29 17:20
阅读 2137·2019-08-29 15:36
阅读 3398·2019-08-29 13:52
阅读 775·2019-08-29 12:29
阅读 1183·2019-08-28 18:10