参考这里
http://javascript.info/tutorial/this
当对象调用方法时,obj.func()的时候,func里面的this就是obj自身,比方说
var obj = {
variable1 : "aaa",
variable2 : "bbb",
method1 : function(param1){this.variable1 = param1;},
method2 : function(param2){this.variable2 = param2;
this.method1(param2);},
method3 : function(){alert(this);}
};
alert(obj.variable1);
alert(obj.variable2);
obj.method1("aabbcc");
alert(obj.variable1);
obj.method2("bbccdd");
alert(obj.variable1);
alert(obj.variable2);
obj.method3();//object Object
var func1 = obj.method3;
func1(); //object Window
obj.method3(); 和 var func1 = obj.method3; func1(); 表面上差不多,结果却不同。
换个比较准确点的说法,对于浏览器来说,obj拥有着method3,所以obj.mehod3里面的this就是拥有者obj;拥有func1的是Window Object,当func1被调用是,this就是拥有者Window了。
javascipt在和html元素协作的时候 ,也存在 拥有者是谁的问题 ,要完全区分似乎 不可能 ,知道有这种 情况就好。参见