以一个最简单的例子把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模式....

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

2005年05月20日 19:57:00 OO的JavaScript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦嗦,而且之间的说法还各有不同,摆在一起就让人看了头大。这里重拾...
  • softart
  • softart
  • 2007年10月27日 15:17
  • 202

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

OO的JavaScript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦嗦,而且之间的说法还各有不同,摆在一起就让人看了头大。这里重拾简单主义,以一个最简单的例子把OO Javascr...
  • kxtk
  • kxtk
  • 2007年02月13日 17:36
  • 933

以一个最简单的例子把OO的JavaScript说明白 (来自花钱的年华)

  • doublel
  • doublel
  • 2005年05月25日 08:23
  • 756

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

  OO的JavaScript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦嗦,而且之间的说法还各有不同,摆在一起就让人看了头大。这里重...
  • cuoguo1111
  • cuoguo1111
  • 2007年06月05日 18:01
  • 502

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

以一个最简单的例子把OO的JavaScript说明白[转]以一个最简单的例子把OO的JavaScript说明白 OO的JavaScript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦...
  • LB3690
  • LB3690
  • 2010年09月06日 15:08
  • 420

【JavaScript】最简单的一个例子

以下是最简单的一个JavaScript例子 我的第一个JavaScript例子【菜鸟教程】 function displayDate(){ document.getElementById...
  • River_Continent
  • River_Continent
  • 2017年08月01日 21:34
  • 422

简单的例子把OO的JavaScript说明白

 OO的javascript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦嗦,而且之间的说法还各有不同,摆在一起就让人看了头大。  这里重拾简单主义,以一个最简单的例子把OO java...
  • xzxw1115
  • xzxw1115
  • 2010年08月25日 17:54
  • 134

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

OO的JavaScript并不高深,麻烦就麻烦在google出来的国人介绍文章经常罗罗嗦嗦,而且之间的说法还各有不同,摆在一起就让人看了头大。这里重拾简单主义,以一个最简单的例子把OO Javascr...
  • kflwz
  • kflwz
  • 2006年03月03日 09:12
  • 727

JavaScript最简单案例

JavaScript是一个功能很强大的脚本语言,这一点众所周知。所以现在开始学习一下基本的JavaScript,算是Web前 段的初体验吧。 首先说,JavaScript是执行在浏览器客户端的脚本...
  • a352193394
  • a352193394
  • 2012年03月05日 17:00
  • 1863

一个最简单的Makefile例子

原文地址:http://hi.baidu.com/hellosim/blog/item/42e78341b40c3e8db2b7dce3.html 转载请注明出处 1.hello.c #in...
  • u013713010
  • u013713010
  • 2015年05月25日 10:10
  • 3545
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:以一个最简单的例子把OO的JavaScript说明白
举报原因:
原因补充:

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