javascript 面向对象基础之四(this关键字)

JavaScript 有一套完全不同于其它语言的对 this 的处理机制。 在五种不同的情况下 ,this 指向的各不相同。

[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();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值