JavaScript 有一套完全不同于其它语言的对 this 的处理机制。 在五种不同的情况下 ,this 指向的各不相同。
[b]全局范围内[/b]
当在全局范围内使用 this,它将会指向全局对象(window)。
[b]函数调用[/b]
这里 this 也会指向全局对象(window)。
从上面的例子可以看出demo方法的调用其实也就是window对象的demo方法调用,因此我们可以通过this.demo()或者window.demo()来调用demo方法。这时this指向的也就是window对象,通过this.name和this.age就会为window对象创建name和age两个属性,因此我们也就可以通过window.name去访问window对象的name属性。
[b]调用构造函数[/b]
如果函数倾向于和 new 关键词一块使用,则我们称这个函数是 构造函数。 在函数内部,this 指向新创建的对象。
这里this指向的便是d对象,因此我们可以通过d.name访问它的属性和方法。
[b]显式的设置 this[/b]
当使用 Function.prototype 上的 call 或者 apply 方法时,函数内的 this 将会被 显式设置为函数调用的第一个参数。
因此函数调用的规则在上例中已经不适用了,在foo 函数内 this 被设置成了 bar
[b]常见误解[/b]
尽管大部分的情况都说的过去,不过第一个规则(译者注:这里指的应该是第二个规则,也就是直接调用函数时,this 指向全局对象) 被认为是JavaScript语言另一个错误设计的地方,因为它从来就没有实际的用途。
一个常见的误解是 test 中的 this 将会指向 Foo 对象,实际上不是这样子的。
为了在 test 中获取对 Foo 对象的引用,我们需要在 method 函数内部创建一个局部变量指向 Foo 对象。
[b]全局范围内[/b]
this
当在全局范围内使用 this,它将会指向全局对象(window)。
[b]函数调用[/b]
function demo(name,age){
this.name = name;
this.age = age;
alert(this); //window object
}
//this.demo("zzg",18);
//window.demo("zzg",18);
demo("zzg",18);
alert(window.name);//zzg
这里 this 也会指向全局对象(window)。
从上面的例子可以看出demo方法的调用其实也就是window对象的demo方法调用,因此我们可以通过this.demo()或者window.demo()来调用demo方法。这时this指向的也就是window对象,通过this.name和this.age就会为window对象创建name和age两个属性,因此我们也就可以通过window.name去访问window对象的name属性。
[b]调用构造函数[/b]
function demo(name,age){
this.name = name;
this.age = age;
alert(this); //object
alert(this instanceof demo); true
}
var d = new demo("zzg",18);
alert(d.name);
如果函数倾向于和 new 关键词一块使用,则我们称这个函数是 构造函数。 在函数内部,this 指向新创建的对象。
这里this指向的便是d对象,因此我们可以通过d.name访问它的属性和方法。
[b]显式的设置 this[/b]
function foo(a,b,c){
alert(this instanceof bar); //true
alert(a);
}
var bar = {};
foo.call(bar,1,2,3);// 数组将会被扩展,如下所示
foo.apply(bar,[1,2,3]);// 传递到foo的参数是:a = 1, b = 2, c = 3
当使用 Function.prototype 上的 call 或者 apply 方法时,函数内的 this 将会被 显式设置为函数调用的第一个参数。
因此函数调用的规则在上例中已经不适用了,在foo 函数内 this 被设置成了 bar
[b]常见误解[/b]
尽管大部分的情况都说的过去,不过第一个规则(译者注:这里指的应该是第二个规则,也就是直接调用函数时,this 指向全局对象) 被认为是JavaScript语言另一个错误设计的地方,因为它从来就没有实际的用途。
var Foo = {};
Foo.method = function(){
function test(){
// this 将会被设置为全局对象(译者注:浏览器环境中也就是 window 对象)
alert(this); //window object
}
test();
}
Foo.method();
一个常见的误解是 test 中的 this 将会指向 Foo 对象,实际上不是这样子的。
为了在 test 中获取对 Foo 对象的引用,我们需要在 method 函数内部创建一个局部变量指向 Foo 对象。
Foo.method = function() {
var that = this;
function test() {
// 使用 that 来指向 Foo 对象
}
test();
}