码迷,mamicode.com
首页 > 其他好文 > 详细

this

时间:2017-08-09 13:10:32      阅读:111      评论:0      收藏:0      [点我收藏+]

标签:移动   定义   logs   text   代码   poi   保存   效果   恰恰   

在函数内部定义的函数,其this也会指向全局,而和我们希望的恰恰相反。代码如下:

var point = {   
 x : 0,   
 y : 0,   
 moveTo : function(x, y) {   
     // 内部函数  
     var moveX = function(x) {   
     this.x = x;//this 绑定到了全局  
    };   
    // 内部函数  
    var moveY = function(y) {   
    this.y = y;//this 绑定到了全局  
    };   
  
    moveX(x);   
    moveY(y);   
    }   
 };   
 point.moveTo(1, 1);   
 point.x; //==>0   
 point.y; //==>0   
 x; //==>1   
 y; //==>1  

 

我们会发现不但我们希望的移动呢效果没有完成,反而会多出两个全局变量。那么如何解决呢?只要要进入函数中的函数时将this保存到一个变量中,再运用该变量即可。代码如下:

var point = {   
 x : 0,   
 y : 0,   
 moveTo : function(x, y) {   
      var that = this;   
     // 内部函数  
     var moveX = function(x) {   
     that.x = x;   
     };   
     // 内部函数  
     var moveY = function(y) {   
     that.y = y;   
     }   
     moveX(x);   
     moveY(y);   
     }   
 };   
 point.moveTo(1, 1);   
 point.x; //==>1   
 point.y; //==>1  

 

this

标签:移动   定义   logs   text   代码   poi   保存   效果   恰恰   

原文地址:http://www.cnblogs.com/lulin1/p/7324435.html

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