博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
图解闭包
阅读量:6315 次
发布时间:2019-06-22

本文共 1277 字,大约阅读时间需要 4 分钟。

说到 闭包 ,这是js不得不提的一个特性,很多传统语言都不具备这样的特性,比如JAVA C等等。

之前看书的时候,总是理解不好什么是闭包!下面就通过手绘一张原理图,来理解一下:

  首先基本上所有的编程语言都有类似的特性,局部方法可以访问外部父类方法的属性,也就是说,子类或子方法可以访问父类的资源。

var num = 11; function func1(){ console.log(num); } func1();

  因此上面的这段代码,我们可以获取到num的值。

 

  父类能否获取到子方法内部的值呢?

function func2(){            var num1 = 22;            num2 = 33;        }        func2();        
console.log(num2);

  当然是不可以的,因为子方法的变量作用域仅仅是子方法的范围,外部是无法获取到的。

  

  那么如何才能在外部获取到子方法的局部变量呢!

  如果是java,一个类的私有属性,可以通过公共的get方法来获取,比如:

class Person{  private String name;  public String getName(){    return name;    }    }

  通过上面的方式可以获取到一个类内部的私有属性,同样的,在js中可以通过某个方法来获取这个方法的局部变量,然后通过这个方法内的方法来读取想要的变量值。

function func3(){            var num3 = 44;            function func4(){                return num3;            }            return func4;        }        var func = func3();        console.log(func());

  参考下面的图解:

  在外部无法获取到func3内部的局部变量,但是func3内部的局部方法func4却可以获取到,因此 返回一个func4的引用 ,这样在外部通过这个func4就可以获取到func3的内部变量。

  虽然是绕了一个圈子,但是在方法外部却通过这样一个手段获取到了内部的值。

  而这个方法内的局部方法func4就叫做闭包,按照很多书上的概念,这个方法搭建了方法内部与方法外部的桥梁,使得在外部也可以任意的获取到方法内部的资源。

  但是闭包会造成变量在内存中持久占用,因此会有一定的性能问题,最好不要轻易使用,即便使用也要在恰当的实际进行释放。

 

  示例的源码:

                        

  运行结果:

本文转自博客园xingoo的博客,原文链接:,如需转载请自行联系原博主。
你可能感兴趣的文章
pdo,更高的sql安全性
查看>>
ckplayer.js视频播放插件
查看>>
数据结构 - 只需选择排序(simple selection sort) 详细说明 和 代码(C++)
查看>>
RSA不对称加密,公钥加密私钥解密,私钥加密公钥解密
查看>>
CSS让浮动元素水平居中
查看>>
KEIL MDK 查看代码量、RAM使用情况--RO-data、RW-data、ZI-data的解释(转)
查看>>
hibernate Disabling contextual LOB creation as connection was null
查看>>
一步步开发自己的博客 .NET版 剧终篇(6、响应式布局 和 自定义样式)
查看>>
想学习超流行的响应式设计?来看看这篇教程【转载】
查看>>
CSS3 圆角(border-radius)详解
查看>>
zoj 3823 Excavator Contest 构造
查看>>
HTTP求
查看>>
JS/jQuery键盘事件介绍
查看>>
Android 随着输入框控件的清除功能ClearEditText,抄IOS输入框
查看>>
CentOS6.5设备MRBS
查看>>
[高中作文赏析]这样的一个人
查看>>
Oracle数据库数据同步方案
查看>>
如何将一个Form中的代码拆分到多个文件中
查看>>
.Net 与 Java 的服务接口相互调用
查看>>
关于json_encode()的使用注意
查看>>