关于Javascript的闭包

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

1.变量作用域

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

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等于调用方法的对象%26nbsp;%26nbsp;%26nbsp;

比如 obj.fun()%26nbsp;%26nbsp; this =obj

若直接是 fun()%26nbsp;%26nbsp; this= window

3.闭包的含义

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

 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

其实就这么简单%26nbsp; 让外部访问内部的变量%26nbsp; 也就是让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的含义%26nbsp; this等于调用方法的对象

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

2.输出"My Object"

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

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

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

%26nbsp;

 示例代码摘自阮一峰BOLG

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值