当前位置: 首页 > 图文教程 > 网络编程 > Javascript > JavaScript 中级笔记 第四章 闭包

Javascript
RDF:Web数据集成的元数据解决方案
你的IP
弹出精彩-弹出式菜单详解
在Web网页上使用VBScript 和JScript
图档结构树的设计与关联
JavaScript电子表
输入日期之改进模式
如果你想打开一个新页面时给浏览者一些惊喜的话,试试这个
HTML文档中用JavaScript调用Microsoft Agent的COM接口编程
JavaScript修改注册表
JavaScript构造XML树结构
一个很不错的主页效果。。你试试!!!
一个用js加密的好玩的东东
在网页上显示一个会移动的透明时钟的代码。。。
如何显示年月日及星期问题
javascript手冊-c
javascript手冊-d
javascript手冊-f
javascript手冊-g
javascript手冊-i

Javascript 中的 JavaScript 中级笔记 第四章 闭包


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-10   浏览: 41 ::
收藏到网摘: n/a

前面已经讲解了 引用,函数重载,作用域和上下文,接下来,讲解JavaScript中另一个重要的知识——闭包。 5,闭包
闭包意味着内层的函数可以引用存在于包围它的函数内的变量,即使外层函数的执行已经终止。
让我们先来看一个闭包的例子。
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

代码①是处于函数内层,不过它可以使用外层的变量num。
闭合还能解决另一个常见的Js问题,全局变量的影响。
通过自动执行匿名函数组合闭包,便可把原本属于全局的变量隐藏起来。看下面的例子:
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

在使用setTimeout时,我们经常也用上了闭包。
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

以这种方式使用setTimeout(),可以避免一些问题。
当然使用闭包 也会带来一些问题。如下代码所示:
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

单击li弹出的序号为 3 ,并不是正确的序号,它引用的值是最后一次的赋值。
我们可以使用下面代码来解决:
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

通过使用闭包对作用域的控制,从而符合了我们的要求。
上面的代码可以分解为:
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

闭包的概念不容易掌握,我也是花了大量时间和精力才理解。
6,小结
笔记(2),(3),(4)讲解了 JavaScript中的几个重要的内容,包括引用,函数重载,作用域,上下文对象和闭包。
引用的关键内容: 指针,数组引用,字符串引用,区别,传值,传址。
函数重载的关键内容: 参数的数量,参数的类型,arguments,伪数组,typeof,constructor,区别-字符串和对象。
作用域的关键内容: 函数划分,全局作用域,全局对象,window对象的属性,局部作用域,显式声明,隐式声明。
上下文对象的关键内容: this变量,call,apply,参数区别,数组。
闭包的关键内容: 内层函数,外层函数,变量,setTimeout,闭包问题,最后一次的赋值,闭包和作用域。