图解闭包
来源:互联网 发布:淘宝收费吗 编辑:程序博客网 时间:2024/04/28 09:08
首先基本上所有的编程语言都有类似的特性,局部方法可以访问外部父类方法的属性,也就是说,子类或子方法可以访问父类的资源。
<!-- 在正常的脚本中,某个方法可以获取到外部的变量,或者全局变量 --> var num = 11; function func1(){ console.log(num); } func1();
因此上面的这段代码,我们可以获取到num的值。
父类能否获取到子方法内部的值呢?
function func2(){ var num1 = 22; num2 = 33; } func2(); <!--console.log(num1); 会报错!--> console.log(num2); <!--可以获取到num2的值,因为不使用var定义变量时,默认是全局变量 -->
当然是不可以的,因为子方法的变量作用域仅仅是子方法的范围,外部是无法获取到的。
那么如何才能在外部获取到子方法的局部变量呢!
如果是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就叫做闭包,按照很多书上的概念,这个方法搭建了方法内部与方法外部的桥梁,使得在外部也可以任意的获取到方法内部的资源。
但是闭包会造成变量在内存中持久占用,因此会有一定的性能问题,最好不要轻易使用,即便使用也要在恰当的实际进行释放。
示例的源码:
<!doctype html><html> <head> </head> <body> <script type="text/javascript"> <!-- 在正常的脚本中,某个方法可以获取到外部的变量,或者全局变量 --> var num = 11; function func1(){ console.log(num); } func1(); <!-- 但是在外部是无法获取方法内部的局部变量的 --> function func2(){ var num1 = 22; num2 = 33; } func2(); <!--console.log(num1); 会报错!--> console.log(num2); <!--可以获取到num2的值,因为不适用var定义变量时,默认是全局变量 --> <!-- 那么如何在外部获取到内部的变量呢!javascript可以办到 --> function func3(){ var num3 = 44; function func4(){ return num3; } return func4; } var func = func3(); console.log(func()); </script> </body></html>
运行结果:
0 0
- 图解闭包
- 图解闭包
- 图解JS闭包
- 图解闭包
- 图解java.io.*包
- 图解Oracle包实例
- 详细图解作用域链与闭包
- WinForm安装包制作,图解
- Wireshark图解教程(抓包)
- SSH分层包框架图解
- 前端高质量知识(四)-JS详细图解作用域链与闭包
- 前端基础进阶(四):详细图解作用域链与闭包
- 前端基础进阶(四):详细图解作用域链与闭包
- 图解Windows Installer制作软件安装包
- 一步一步部署SSIS包图解教程
- 一步一步部署SSIS包图解教程
- 一步一步部署SSIS包图解教程
- 一步一步部署SSIS包图解教程1
- 显著性检测
- AC自动机算法及模板
- [深度学习论文笔记][Image Classification] Very Deep Convolutional Networks for Large-Scale Image Recognitio
- Hibernate开启了二级缓存后查询语句为什么没有被缓存
- 【并查集】构造完全图
- 图解闭包
- 新手使用Maven的那些坑
- javascript学习笔记
- [刷题]算法竞赛入门经典(第2版) 5-11/UVa12504 - Updating a Dictionary
- Hadoop单机、伪分布式集群搭建(十分详细)
- 分页查询
- LeetCode[225] Implement Stack using Queues
- jsp中动作元素
- 请求重定向与请求转发的区别