不同的函数调用中this的指向

一:纯粹的函数调用

  这是函数的最通常用法,属于全局性调用,因此this就代表全局对象Global(即window)。

二:作为对象方法的调用

  函数还可以作为某个对象的方法调用,这时this就指这个上级对象。

function test(){
  alert(this.x);
}
var o = {};
o.x = 1;
o.m = test;
o.m(); // 1

三:作为构造函数调用

  所谓构造函数,就是通过这个函数生成一个新对象(object)。这时,this就指这个新对象。  

function test(n){  
    this.x = n;
 }   
var o = new test(3);   
alert(o.x); //3

四: apply调用

  apply()是函数对象的一个方法,它的作用是改变函数的调用对象,它的第一个参数就表示改变后的调用这个函数的对象。因此,this指的就是这第一个参数。

  apply()的参数为空时,默认调用全局对象。

五:闭包中的函数调用 

var name = "Window Name";
var object = {
    name : "my object",
    getNameFuc : function(){
        return function(){
            return this.name;    
        };
    }        
};
alert(object.getNameFuc()());  //Window Name


var name = "Window Name";
var object = {
    name :"my object",
    getNameFuc : function(){
        var that = this;
        return function(){
            return that.name;    
        };
    }
}
alert(object.getNameFuc()());  //my object

function makeFunc() {  
      var name = "Mozilla";  
      function displayName() {  
        alert(name);  
      }  
      return displayName;  
    }  
      
 makeFunc()();   //Mozilla
posted @ 2013-01-14 17:19  ~小章鱼~  阅读(168)  评论(0编辑  收藏  举报