|
闭包的“闭”是指闭包的内部环境对外部不可见,也就是说闭包具有控制外部域的能力但是又能防止外部
对闭包的反向控制,换句话说,闭包的领域是对外封闭的。这一特点是因为javascript闭包是通过function实现的
所以它天然具有基本的函数特征,在闭包内声明的变量,闭包外的任何环境都无法访问的,除非闭包向外部
环境提供了访问它们的接口。
一个体现闭包本质的例子
1. <html> 2. 3. <head> 4. 5. <title>Example-22.2 闭包的本质</title> 6. 7. </head> 8. 9. <body> 10. 11. <script> 12. 13. <!- 14. 15. //A是一个普通的函数 16. 17. function A(a) 18. 19. { 20. 21. return a; 22. 23. } 24. 25. //B是一个带函数返回值的函数 26. 27. function B(b) 28. 29. { 30. 31. return function (){ 32. 33. return b; 34. 35. } 36. 37. } 38. 39. var x = A(10); 40. 41. //因为A除了返回a外什么也没做,执行A()函数后,调用堆栈被销毁 42. 43. //没有产生闭包,或者说在调用"瞬间"产生了闭包,然后马上被销毁 44. 45. var y = B(20); 46. 47. //因为B返回了一个匿名函数引用,它访问到B()被调用时产生的环境 48. 49. //因此这里产生了一个"闭包结构"(closure或者function instance) 50. 51. //在它的环境中,b = 20,因此y()的返回结果是20 52. 53. var z = B(30); 54. 55. //同样,这里产生了第二个"闭包结构" 56. 57. //在它的环境中,b = 30,因此z()的返回结果是30 58. 59. alert(x); //得到10 60. 61. alert(y()); //得到20 62. 63. alert(z()); //得到30 64. 65. --> 66. 67. </script> 68. 69. </body> 70. 71. </html> 72. 闭包是一种引用结构,至少在javascript中是这样,javascript中的闭包也可以理解为一种“函数实例引用” 1. javascript的对象中的是有属性其实就是环境中的非持久性变量,而在构造函数内部用this.foo = function(){...} 形式定义的方法其实也是闭包的一种创建形式,只是它提供了一种开放了“外部接口”的闭包 |
|