码迷,mamicode.com
首页 > 编程语言 > 详细

关于Javascript的闭包

时间:2015-08-16 00:40:13      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:

要理解javascript的闭包 关键是弄明白三样事情

1.变量作用域

一言以蔽之  函数内部可以访问函数外部的字段  而反之不行

1   var n=999;
2 
3   function f1(){
4     alert(n);
5   }
6 
7   f1(); // 999
1     function f1(){
2       var n=999;
3     }
4
5     alert(n); // error

此处有一坑是 若在函数内声明变量不使用var关键字 相当于是声明全局变量 也就是window的变量

2.this的含义

this等于调用方法的对象   

比如 obj.fun()   this =obj

若直接是 fun()   this= window

3.闭包的含义

闭包其实就是一个定义在函数内部的函数   使外部能访问函数内部的变量 

 1       function f1(){
 2 
 3         var n=999;
 4 
 5         function f2(){
 6           alert(n);
 7         }
 8 
 9         return f2;
10 
11       }
12 
13       var result=f1();
14 
15       result(); // 999

其实就这么简单  让外部访问内部的变量  也就是让f1的局部变量n成为了全局变量

4. 思考题

若能理解这两题,则算是明白闭包的含义 请先仔细思考

代码一:

 1       var name = "The Window";
 2 
 3       var object = {
 4         name : "My Object",
 5 
 6         getNameFunc : function(){
 7           fun = function(){
 8             return this.name;
 9           };
10         return fun;
11         }
12 
13       };
14 
15       alert(object.getNameFunc()());  

代码二:

 1       var name = "The Window";
 2 
 3       var object = {
 4         name : "My Object",
 5 
 6         getNameFunc : function(){
 7           var that = this;
 8           fun = function(){
 9             return that.name;
10           };
11          return fun;
12         }
13 
14       };
15 
16       alert(object.getNameFunc()());

5.思考题解析

1.输出"The Window"

 当执行object.getNameFunc()时返回的是fun函数

 object.getNameFunc()() 相当于是执行fun()

 此时你翻上去看下this的含义  this等于调用方法的对象

   fun()前没有对象 说明此时的对象默认是window 所以返回"The Window"

2.输出"My Object"

 当执行object.getNameFunc()时  this=object 并把object保存在that变量中

 所以当执行object.getNameFunc()()时  也就是fun()  虽然是此时默认对象是window

 但调用的是that的name 也就是object

 

 示例代码摘自阮一峰BOLG

关于Javascript的闭包

标签:

原文地址:http://www.cnblogs.com/threezj/p/4733424.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!