javascript之闭包
2015-11-22 23:15
549 查看
看了很多篇关于闭包的文章(ps,当然很多语言中都存在闭包的概念,如c,c++等),很模糊也很难懂,下面简单的介绍一下今天所理解的内容。
JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。
那么javascript闭包(closure)是什么呢 ?官方给出的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。简单的说就是访问
另一个函数作用域中的变量的函数。
要理解闭包,首先需要了解变量的概念,下面就通过几个例子来简单的了解一下,jvavascript中的变量。
1.局部变量
2.全局变量
函数b被包括在函数a的内部,函数b是可以读取a中的局部变量,并把b作为返回值,那么我们就可以在外部得到它的内部变量。
那么上述所说的函数b()就是一个简单的闭包。
今天就到这,明天继续!
理解会有所欠缺!请多指点。
JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。
那么javascript闭包(closure)是什么呢 ?官方给出的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。简单的说就是访问
另一个函数作用域中的变量的函数。
要理解闭包,首先需要了解变量的概念,下面就通过几个例子来简单的了解一下,jvavascript中的变量。
1.局部变量
function show(){ var message = "dada";//局部变量只能在本函数中使用 } show();//调用函数 alert(message);//函数外部不能使用局部变量
2.全局变量
var message = "dada"; function show(){ alert(message);//使用全局变量 } show();从上面我们知道,在函数外面一般是不能使用局部变量的。但是如果我们一定要使用呢?试着看看下面的代码:
function a(){ var i=0; function b(){ alert(++i); } return b; } var c = a(); c();//第一次输出的是1(即为i+1后的值)
函数b被包括在函数a的内部,函数b是可以读取a中的局部变量,并把b作为返回值,那么我们就可以在外部得到它的内部变量。
那么上述所说的函数b()就是一个简单的闭包。
今天就到这,明天继续!
理解会有所欠缺!请多指点。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- 深入理解PHP之匿名函数
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享
- 如何创建对象以及jQuery中创建对象的方式
- IE8开发人员工具教程(二)