Javascript 闭包的秘密
2009-01-11 20:13
239 查看
Javascript 中的闭包其实很改语言中很难理解的一部分。感谢 Stuart 提供了那么棒的 PPT,它深入浅出的解释了 Javascript 的闭包技术。
而我“自作主张”地在这份 PPT 中加入了部分的注释(希望没有影响阅读),主要的内容在这里简要整理下。
但不要咬文嚼字,我们简单的可以理解为
回调函数(callback)
事件句柄(event handle)
其中 dec 为私有,that 变量引用 Container 同时 service 函数构成了个闭包。
垃圾回收
最后,PPT 可以在这里下载,同时需要进一步有关闭包的信息,为之漫笔翻译了份很详实的文档,强烈建议看下。
原文:http://www.gracecode.com/Archive/Display/2385
而我“自作主张”地在这份 PPT 中加入了部分的注释(希望没有影响阅读),主要的内容在这里简要整理下。
闭包的概念
“官方”的解释“闭包”,是指拥有多个变量和绑定了这些变量的环境的 表达式(通常是一个函数),因而这些变量也是该表达式 的一部分。
但不要咬文嚼字,我们简单的可以理解为
闭包是个函数,而它“记住了周围发生了什么”。表现为由“一个函数”体中定义了“另个函数”
function outer () { ... function inner () { ... } }
闭包的作用
setTimeout/setInterval回调函数(callback)
事件句柄(event handle)
模块化代码
function Container(param) { var sercert = 3; this.member = param; var that = this; // 注意这行 function dec() { return (sercert > 0) ? --secret : false; } this.service = function() { return (dec()) ? that.member : null; } }
其中 dec 为私有,that 变量引用 Container 同时 service 函数构成了个闭包。
注意 Exploer 下闭包的“特殊情况”
循环问题垃圾回收
最后,PPT 可以在这里下载,同时需要进一步有关闭包的信息,为之漫笔翻译了份很详实的文档,强烈建议看下。
原文:http://www.gracecode.com/Archive/Display/2385
相关文章推荐
- Javascript 闭包的秘密
- 自我学习——javascript——闭包的本质
- javascript关于事件与闭包
- 让你分分钟理解 JavaScript 闭包
- 深入理解javascript原型和闭包(10)——this
- JavaScript同步、异步、回调执行顺序之经典闭包(setTimeout面试题分析)
- javascript,jquery(闭包概念)(转)
- 深入理解javascript原型和闭包(5)——instanceof
- 深入理解javascript原型和闭包(12)——简介【作用域】
- (14)javascript 函数表达式 递归、闭包
- JavaScript那些事儿-高大不好上的闭包
- javascript 闭包
- javascript基础八(知识点类闭包)
- JavaScript 闭包究竟是什么
- 学习Javascript闭包(Closure)
- javascript的闭包
- javascript闭包
- JavaScript中的闭包
- javascript 之闭包详解
- JavaScript 闭包