1、全局中 this 就是 window,this === window;
2、函数在预编译时 this 同样是 window, this === window;
3、call / apply 可以改变 this 的指向;
4、对象调用方法时(object.function()),谁调用的方法 this 指向谁。
例如:
console.log(window === this); // true
function demo(){
console.log(window === this); // true
}
demo();
function Test(){
this.name = "zhang";
this.sayName = function(){
console.log(this.name);
}
}
var test = new Test();
test.sayName(); // this 指向test对象
详细区分请看下面代码:
var temp = "111";
function demo(){
var temp = "222";
console.log(this.temp);
}
var obj1 = {
temp : "333",
test : function(){
console.log(this.temp);
}
}
var obj2 = {
temp : "444",
test : function(fun){
fun();
}
}
var fun = obj1.test;
demo(); // 111,函数中this指向window
obj1.test(); // 333,obj1调用的test方法,this指向obj1
obj2.test(demo); // 111,obj2.test()会执行传入的fun方法,fun方法执行时this指向window
fun(); // 111,同函数demo执行,this指向window
obj2.test(obj1.test); // 111,obj2.test()会执行传入的fun方法,fun方法执行时this指向window
demo.call(obj1); // 333,call改变了this指向,this指向传入的参数obj1
obj2.test = obj1.test;
obj2.test(); // 444,obj2调用的test方法,this指向obj2