Dev@Free

zJun's Tech Weblog

在javascript中实现继承关系

意译自KevLinDev上一篇文章,才疏学浅,望指正,英文原文可到这里查看。

    javascript脚本语言是支持面向对象编程(Object Oriented Programming )的,只是javascript实现的方式比较特别,与C++和java中的实现方式不同。在javascript中我们需要借助prototype对象来访问父类的方法,下面将讨论在javascript中实现OOP中最基本的特征关系 --- 继承

首先,我们从最基本的开始:在javascript中创建对象。创建一个对象包括2步:
1) 创建一个和你想要创建的对象同名的函数(这里可以把这个函数理解为java中的构造函数);
2) 通过调用 new 上面创建的函数名 的方式创建一个对象实例;
// 创建同名函数
function Person(first, last) {
    
this.first =
 first;
    
this.last  =
 last;
}
// 创建实例

var person = new Person("John""Dough");

注意:构造函数中的this指针指向当前的创建的对象,这与java中的表示是一致的。通过this指针我们可以操作对象的属性。

然后,设置对象的方法:
Person.prototype.toString() {
    
return this.first + " " + this
.last;
}
alert( person.toString() ); 
// displays "John Dough"

alert( person ); // alert函数将默认调用toString()函数

在这里我们用到了javascript中的prototype属性。所有的javascript对象都拥有一个prototype属性,javascript就是通过这个属性来实现继承关系的。具体的实现机制是这样的:当你访问一个对象的属性时,编译器将先查找对象的属性看有没有匹配的。如果没有找到,将继续查找这个对象的prototype属性所指的对象,看是否存在匹配的属性。如果还是没有找到,编译器将检查当前对象的prototype是否拥有prototype属性,如果有将继续查找下去。以此类推,直到查找完所有的prototype属性。
从这个过程不难看出,存在着一个类似于继承的访问链,可以把prototype对象指向我们要继承的父类,以此来访问父类的方法。

接下来,我们新建一个类Employee来继承上面的Person类,并且新增一个属性id,在Employee的构造函数中只是初始化属性id,而父类中的属性将由Person的构造函数类设置:
function Person(first, last) {
if ( arguments.length > 0
 )
    
this
.init(first, last);
}

Person.prototype.init 
= function
(first, last) {
    
this.first =
 first;
    
this.last  =
 last;
}

Employee.prototype 
= new
 Person();
Employee.prototype.constructor 
=
 Employee;
Employee.superclass 
=
 Person.prototype;

function
 Employee(first, last, id) {
    
if ( arguments.length > 0
 )
        
this
.init(first, last, id);
}

Employee.prototype.init 
= function
(first, last, id) {    
    
// Call superclass method

    Employee.superclass.init.call(this, first, last);

    
// init properties

    this.id = id;
}

可以看到,我们把初始化属性的操作提取出来放到了一个init函数中,这样做是为了方便在子类中调用。注意其中的"Employee.superclass = Person.prototype;",这里是一个技巧,方便下面在子类中调用父类的方法。
另一个需要注意的地方是"Employee.superclass.init.call(this, first, last);":对于所有对象中的方法来说,都可以通过两个方法来调用--"call" 和 "apply".
这里使用了call方法,其中第一个参数是将在调用的方法中访问的对象,后面的参数与调用方法的参数一致。
 apply方法的使用与call大致一致,不同在于除了第一个参数外,后面是一个参数数组。

下面附上完整的例子和类图:

继承关系图如下:
o_javascriptOOP.gif

代码

posted on 2006-03-06 19:40 zJun's帛罗阁 阅读(3738) 评论(6)  编辑  收藏

评论

# re: 在javascript中实现继承关系 2006-03-06 22:06 dudu

建议放在其他技术区!  回复  更多评论   

# re: 在javascript中实现继承关系 2006-03-07 09:14 Haha

很好!谢谢!  回复  更多评论   

# re: 在javascript中实现继承关系 2006-03-24 18:40 查到这来了

Person.prototype.toString() {
return this.first + " " + this.last;
}
这里写错了!
应该是:
Person.prototype.toString = function(){
return this.first + " " + this.last;
}  回复  更多评论   

# re: 在javascript中实现继承关系 2006-05-24 18:35 student02370236

在Javascript中this的含义和在JAVA中是不一样的!!!
在javascript中this是指向全局对象的...

在O'REILLY的<JavaScript权威指南>一书中有如下的描述:
In top-level code (i.e., JavaScript code that is not part of a function), you can use the JavaScript keyword this to refer to the global object. Within functions, this has a different use(Javascript Definitive Guide:Part 4.6.1)  回复  更多评论   

# re: 在javascript中实现继承关系 2006-05-24 18:41 student02370236

我看了本文的英文原版,我认为他对这个this的描述有问题...  回复  更多评论   

# re: 在javascript中实现继承关系 2008-05-23 11:32 ss

aaaaa  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
 

导航

<2006年3月>
2627281234
567891011
12131415161718
19202122232425
2627282930311
2345678

统计

常用链接

留言簿(15)

随笔分类

随笔档案

相册

收藏夹

博客

文档

站点

论坛

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜