以一个最简单的例子把OO的JavaScript说明白

原创 2005年05月20日 19:57:00

OO的JavaScript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦嗦,而且之间的说法还各有不同,摆在一起就让人看了头大。
这里重拾简单主义,以一个最简单的例子把OO Javascript说明白。

1.一个颇为精简的例子

只需理解三个关键字:
第一个是function ,JS世界里Class的定义用"function",function里面的内容就是构造函数的内容。

第二个是this指针,代表调用这个函数的对象。

第三个是prototype,用它来定义成员函数, 比较规范和保险。

//定义Circle类,拥有成员变量r,常量PI和计算面积的成员函数area()
function Circle(radius)
{  
  this.r = radius;
}
Circle.PI = 3.14159;
Circle.prototype.area = function(  ) {return Circle.PI * this.r * this.r;}
//使用Circle类
var c = new Circle(1.0);  
alert(c.area());
另外成员函数定义还可以写成这样:
function compute_area(){return Circle.PI * this.r * this.r;}
Circle.prototype.area=compute_area;

2.继承

注意两点
1.定义继承关系 ChildCircle.prototype=new Circle(0); 其中0是占位用的
2.调用父类的构造函数 
     this.base=Circle;
     this.base(radius);

//定义ChildCircle子类
function ChildCircle(radius)
{  
     this.base=Circle;
     this.base(radius);
}

ChildCircle.prototype=new Circle(0);
function Circle_max(a,b)
{
    if (a.r > b.r) return a;

    else return b;
}
ChildCircle.max = Circle_max;
//使用ChildCircle子类
var c = new ChildCircle(1);
var d = new ChildCircle(2);  
var bigger = d.max(c,d);
alert(bigger.area());

3.var式定义
JS还支持一种var Circle={raidus:1.0,PI:3.1415}的形式,语法就如CSS的定义。
因此如果Circle只有一个实例,下面的定义方式更简洁:

var newCircle=
{
r:1.0,
PI:3.1415,
area: function(){ return this.PI * this.r * this.r;}
};
alert(newCircle.area());
BTW.吃饱了撑着可以看看Rails带的OO Javascript库--Prototype
其实,Javascript现在的语法真的不适合那么别扭的写成OO模式....

相关文章推荐

blockchain 区块链200行代码:在JavaScript实现的一个简单的例子

了解blockchain的概念很简单(区块链,交易链块):它是分布式的(即不是放置在同一台机器上,不同的网络设备上的)数据库支持主办记录日益增长的名单。但是,这也是容易混淆blockchain与我们试...

一个简单的例子:javascript设置默认日期范围为最近40天(2)

上一个例子是:通过javascript输出所选择的日期 ,就是实现了选择日期,然后把选择的日期输出,这么一个功能。 不过实际项目中,测试人员说客户的需求是点击进入页面后,自动查询最近40天的数据。 ...
  • yupeigu
  • yupeigu
  • 2017年01月06日 11:21
  • 167

中级JavaScript例子, 如何实现一个简单实用的模板套用机制, GXTemplate , 第一章(估计要写9章)

解说一下 GXTemplate, 一个模板套用类库 (谈不上框架), v0.1版本的实现过程 (JavaScript)...

中级JavaScript例子, 如何实现一个简单实用的模板套用机制, GXTemplate , 第4章(估计要写9章)

第4章 接 第2章 http://blog.csdn.net/zhgangxuan/article/details/50636985  第4章 下载地址  https://github.c...

中级JavaScript例子, 如何实现一个简单实用的模板套用机制, GXTemplate , 第2章(估计要写9章)

接 第1章 http://blog.csdn.net/zhgangxuan/article/details/50610883  第2章 下载地址  https://github.com/zh...

一个简单的例子:通过javascript输出所选择的日期(1)

一直在用公司的报表工具做报表,报表里最常用的查询条件就是开始日期、结束日期。 自己会一点html和js,于是就想用html+javascript来实现选择查询日期,以及做出相应。 实现之后,觉得这个还...
  • yupeigu
  • yupeigu
  • 2017年01月05日 18:40
  • 327

QML语法从一个简单的例子说起

  • 2015年05月07日 18:51
  • 42KB
  • 下载

一个简单的例子看明白如何利用window.location.hash实现ajax操作时浏览器的前进/后退功能

我们知道JavaScript中很早就提供了window.history对象,利用history对象的forward()、go()、back()方法能够方便实现不同页面之间的前进、后退等这种导航功能。但...

一个简单的小例子让你明白c#中的委托

模拟主持人发布一个问题,由多个嘉宾来回答这个问题。 分析:从需求中抽出Host (主持人) 类和Guests (嘉宾) 类。 作为问题的发布者,Host不知道问题如何解答。因此它只能发布这...

一个简单的例子看明白如何利用window.location.hash实现ajax操作时浏览器的前进/后退功能

我们知道JavaScript中很早就提供了window.history对象,利用history对象的forward()、Go()、back()方法能够方便实现不同页面之间的前进、后退等这种导航功能。但...
  • Truong
  • Truong
  • 2017年06月09日 16:58
  • 247
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:以一个最简单的例子把OO的JavaScript说明白
举报原因:
原因补充:

(最多只允许输入30个字)