您的位置:首页 > Web前端 > JavaScript

Javascript 闭包的秘密

2009-01-11 20:13 239 查看
Javascript 中的闭包其实很改语言中很难理解的一部分。感谢 Stuart 提供了那么棒的 PPT,它深入浅出的解释了 Javascript 的闭包技术。

而我“自作主张”地在这份 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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: