Javascript闭包
2008-07-08 09:17
176 查看
闭包的“闭”是指闭包的内部环境对外部不可见,也就是说闭包具有控制外部域的能力但是又能防止外部
对闭包的反向控制,换句话说,闭包的领域是对外封闭的。这一特点是因为javascript闭包是通过function实现的
所以它天然具有基本的函数特征,在闭包内声明的变量,闭包外的任何环境都无法访问的,除非闭包向外部
环境提供了访问它们的接口。
一个体现闭包本质的例子
对闭包的反向控制,换句话说,闭包的领域是对外封闭的。这一特点是因为javascript闭包是通过function实现的
所以它天然具有基本的函数特征,在闭包内声明的变量,闭包外的任何环境都无法访问的,除非闭包向外部
环境提供了访问它们的接口。
一个体现闭包本质的例子
<html> <head> <title>Example-22.2 闭包的本质</title> </head> <body> <script> <!- //A是一个普通的函数 function A(a) { return a; } //B是一个带函数返回值的函数 function B(b) { return function (){ return b; } } var x = A(10); //因为A除了返回a外什么也没做,执行A()函数后,调用堆栈被销毁 //没有产生闭包,或者说在调用"瞬间"产生了闭包,然后马上被销毁 var y = B(20); //因为B返回了一个匿名函数引用,它访问到B()被调用时产生的环境 //因此这里产生了一个"闭包结构"(closure或者function instance) //在它的环境中,b = 20,因此y()的返回结果是20 var z = B(30); //同样,这里产生了第二个"闭包结构" //在它的环境中,b = 30,因此z()的返回结果是30 alert(x); //得到10 alert(y()); //得到20 alert(z()); //得到30 --> </script> </body> </html> 闭包是一种引用结构,至少在javascript中是这样,javascript中的闭包也可以理解为一种“函数实例引用”
javascript的对象中的是有属性其实就是环境中的非持久性变量,而在构造函数内部用this.foo = function(){...}
形式定义的方法其实也是闭包的一种创建形式,只是它提供了一种开放了“外部接口”的闭包
摘自《javascript王者归来》
相关文章推荐
- javascript闭包
- 深入理解javascript闭包
- 深入理解Javascript闭包
- 正确理解javascript闭包
- 深入理解JavaScript闭包 (转)
- 深入理解JavaScript闭包(closure)
- Javascript闭包
- Javascript闭包(Closure)
- javascript闭包(2)
- 深入理解JavaScript闭包(closure)
- Javascript闭包模拟私有成员
- 献给各位新手——真正搞清楚javascript闭包(2)
- JavaScript闭包(转)
- Javascript闭包技术 .
- 深入理解javascript闭包
- 《Professional Javascript For Web Developers 3rd Edition》读书笔记:javascript闭包中的this对象
- 揭开Javascript闭包的真实面目
- 深入理解Javascript闭包 新手版
- javascript闭包,arguments和prototype
- javascript闭包问题