码迷,mamicode.com
首页 > Web开发 > 详细

js 中的this

时间:2015-03-03 13:15:44      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:

this是js的一个关键字,随着函数使用场合不同,this的值会发生变化。但是总有一个原则,那就是this指的是调用函数的那个对象。

 1、纯粹函数调用。

 
  1. function test() {     
  2.     this.x = 1;      
  3.     alert(x);  
  4. }  
  5.   
  6. test(); 

 


其实这里的this就是全局变量。看下面的例子就能很好的理解其实this就是全局对象Global。其实这里的this就是全局变量。看下面的例子就能很好的理解其实this就是全局对象Global。

 

 
  1. var x = 1;  
  2. function test() {  
  3.     alert(this.x);  
  4. }  
  5. test();//1  
  6.   
  7. var x = 1;  
  8. function test() {  
  9.     this.x = 0;  
  10. }  
  11. test();  
  12. alert(x);//0  

 2、作为对象方法调用,那么this就是指这个上级对象。

 
  1. function test() {  
  2.     alert(this.x);  
  3. }  
  4.   
  5. var o = {};  
  6. o.x = 1;  
  7. o.m = test;  
  8. o.m(); //1  


3、作为构造函数调用。所谓构造函数,就是生成一个新的对象。这时,这个this就是指这个对象。

 
  1. function test() {      
  2.      this.x = 1;  
  3. }  
  4. var o = new test();  
  5. alert(o.x);//1  


4、apply调用

 
  1. var x = 0;  
  2. function test() {  
  3.     alert(this.x);  
  4. }  
  5.   
  6. var o = {};  
  7. o.x = 1;  
  8. o.m = test;  
  9. o.m.apply(); //0  
  10. o.m.apply(o);//1  


当apply没有参数时,表示为全局对象。所以值为0。

 

文章来源:http://blog.csdn.net/zhikun518/article/details/7936603

js 中的this

标签:

原文地址:http://www.cnblogs.com/forver/p/4310570.html

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