1 / 5
文档名称:

js闭包理解面试题.docx

格式:docx   大小:66KB   页数:5页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

js闭包理解面试题.docx

上传人:likuilian1 2020/12/26 文件大小:66 KB

下载得到文件列表

js闭包理解面试题.docx

相关文档

文档介绍

文档介绍:一、什么是闭包?
官方”的解释是:闭包是一个拥有许多变量和绑泄了这些变量的环境的表达式(通常是 一个函数),因而这些变量也是该表达式的一部分。
相信很少有人能直接看懂这句话,因为他描述的太学术。其实这句话通俗的来说就是:
JavaScript中所有的function都是一个闭包 不过一般来说,嵌套的function所产生的闭 包更为强大,也是大部分时候我们所谓的"闭包”。看下而这段代码:
1 function a () { 2 var i = 0; 3 function b() { alert (++i) ; } 4 return b; 5 }6 var c = a() c ();
这段代码有两个特点:
1、 函数b嵌套在函数a内部:
2、 函数a返回函数b°
引用关系如图:
function a() {
var i = 0;4
► function b() {
alert(+4-i):— return b;
}
——var c = a ();
c();
这样在执行完var c=a()后,变量c实际上是指向了函数b,再执行c()后就会弹出一个 窗口显示i的值(第一次为1)。这段代码其实就创建了一个闭包,为什么?因为函数a外的 变量c引用了函数a内的函数b,就是说:
当函数a的内部函数b被函数a外的一个变量引用的时候,就创建了一个闭包。
让我们说的更透彻一些。所谓"闭包”,就是在构造函数体内定义另外的函数作为目标对 象的方法函数,而这个对象的方法函数反过来引用外层函数体中的临时变量。这使得只要目 标对象在生存期内始终能保持其方法,就能间接保持原构造函数体当时用到的临时变疑值。 尽管最开始的构造函数调用已经结束,临时变量的名称也都消失了,但在目标对象的方法 内却始终能引用到该变量的值,而且该值只能通这种方法来访问。即使再次调用相同的构适 函数,但只会生成新对象和方法,新的临时变量只是对应新的值,和上次那次调用的是%自 独立的。
二、变量的作用域
要理解闭包,首先必须理解Javascript特殊的变量作用域。
变疑的作用域无非就是两种:全局变量和局部变量。
Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量。
下而通过一段代码来看一下
1 var n=999;2 function fl(){3 alert(n);4 }5 fl (); // 999
坍一方而,在函数外部自然无法读取函数内的局部变量。
1 function fl (){2 var n=999;3 }4 alert(n); // error
这里有一个地方需要注意,函数内部声明变量的时候,一左要使用var命令。如果不用的话,
你实际上声明了一个全局变戢!
1 function fl (){2 n=999;3 }4 fl ();5 alert(n); // 999
以上只是一个关于javascript变量作用域基础的例子。
三、如何从外部读取局部变量?(闭包)
我们有时候需要得到函数内的局部变量。但是,前而已经说过了,正常情况下,这是办 不到的,只有通过变通方法才能实现。
当然这个变通的方法便是使用闭包,下而再通过一个例子来看一下
:function fl () {2
n=999;3
func