参考这里javascript
http://javascript.info/tutorial/thishtml
当对象调用方法时,obj.func()的时候,func里面的this就是obj自身,比方说
java
var obj = {浏览器
variable1 : "aaa",ui
variable2 : "bbb",this
method1 : function(param1){this.variable1 = param1;},spa
method2 : function(param2){this.variable2 = param2; htm
this.method1(param2);},对象
method3 : function(){alert(this);}ip
};
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元素协做的时候 ,也存在 拥有者是谁的问题 ,要彻底区分彷佛 不可能 ,知道有这种 状况就好。参见