摘要:闭包是什么首先,放一个概念函数加函数内部能访问到的局部变量就组成了一个闭包那闭包又有什么作用呢闭包常常用来间接访问一个变量。其实这是翻译问题,闭包的原文是,跟包没有任何关系。所以函数套函数只是为了造出一个局部变量,跟闭包无关。
JS闭包是什么?
首先,放一个概念:
函数 加 函数内部能访问到的局部变量 就组成了一个闭包
那闭包又有什么作用呢?
闭包常常用来「间接访问一个变量」。换句话说,「隐藏一个变量」。
通常做法是 暴露一个访问器(函数),让别人可以「间接访问」那个变量。
有这样一段代码:
var i = "i am in windows" var test = function(){ var a = 0; var b = function(){ console.log(a) } return b }
很明显 a 是 test 这个函数对象内的局部变量 而在其内部 b 又引用了这个对象a 这就是一个闭包
a变量 和 b 函数对象组成了一个闭包
那为什么要test函数里要再套一个b函数呢?
是因为需要局部变量,所以才把 a 放在一个函数里,如果不把 a 放在一个函数里,a 就是一个全局变量了,达不到使用闭包的目的——隐藏变量。
有些人看到「闭包」这个名字,就一定觉得要用什么包起来才行。其实这是翻译问题,闭包的原文是 Closure,跟「包」没有任何关系。
所以函数套函数只是为了造出一个局部变量,跟闭包无关。
那为什么又要 return b 呢?
因为如果不 return,你就无法使用这个闭包。return b 的目的只是让外面可以访问到这个 b 函数。
所以 return b 只是为了 b 能被使用,也跟闭包无关。
下面看下 闭包的庐山真面目:
看到了吗 function scope 里面出现了Closure 和 Global
Closure里有 a 变量的值 也就是 0
那么我们是否可以猜测 我们在首行定义的全局变量 i 是不是就在Global这个 function scope 里面?
验证下
全局变量 i 确实就在 Global里面
其实,function scope内默认有个名为 Globe 的全局引用(有了这个引用,就可以直接调用 Globe 的属性或方法)
而在Closure里的变量或方法 外部是无法直接访问的
这就是 隐藏 了一个变量
by 潘小闲
参考资料:JS中的闭包是什么
同步github
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/88451.html
摘要:大名鼎鼎的闭包面试必问。闭包的作用是什么。看到闭包在哪了吗闭包到底是什么五年前,我也被这个问题困扰,于是去搜了并总结下来。关于闭包的谣言闭包会造成内存泄露错。闭包里面的变量明明就是我们需要的变量,凭什么说是内存泄露这个谣言是如何来的因为。 本文为饥人谷讲师方方原创文章,首发于 前端学习指南。 大名鼎鼎的闭包!面试必问。请用自己的话简述 什么是「闭包」。 「闭包」的作用是什么。 首先...
摘要:当初看这个解释有点懵逼,理解成闭包就是函数中的函数了。里的闭包最近不满足于只干前端的活,开始用起了。里的闭包最近在学习语言,让我们来看一下语言里的闭包。在中,闭包特指将函数作为值返回的情况,被返回的函数引用了生成它的母函数中的变量。 本人开始接触编程是从js开始的,当时网上很多人说闭包是难点,各种地方对闭包的解释也是千奇百怪。如今开始接触js以外的各种编程语言,发现不光是js,php、...
摘要:当初看这个解释有点懵逼,理解成闭包就是函数中的函数了。里的闭包最近不满足于只干前端的活,开始用起了。里的闭包最近在学习语言,让我们来看一下语言里的闭包。在中,闭包特指将函数作为值返回的情况,被返回的函数引用了生成它的母函数中的变量。 本人开始接触编程是从js开始的,当时网上很多人说闭包是难点,各种地方对闭包的解释也是千奇百怪。如今开始接触js以外的各种编程语言,发现不光是js,php、...
摘要:内部的称为内部函数或闭包函数。过度使用闭包会导致性能下降。,闭包函数分为定义时,和运行时。循环会先运行完毕,此时,闭包函数并没有运行。闭包只能取得外部函数中的最后一个值。事件绑定种的匿名函数也是闭包函数。而对象中的闭包函数,指向。 闭包概念解释: 闭包(也叫词法闭包或者函数闭包)。 在一个函数parent内声明另一个函数child,形成了嵌套。函数child使用了函数parent的参数...
阅读 881·2021-11-22 13:53
阅读 2514·2021-10-15 09:40
阅读 983·2021-10-14 09:42
阅读 3399·2021-09-22 15:59
阅读 871·2021-09-02 09:47
阅读 2303·2019-08-30 15:54
阅读 1412·2019-08-29 17:14
阅读 373·2019-08-29 15:15