OO的JavaScript

原创 2006年05月25日 23:23: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模式....

Javascript OO

javascript OO1.原始方式:var person = new Object();person.name = “Nicholas”;person.age = 29;person.job = ...
  • yanyongshan
  • yanyongshan
  • 2010年03月06日 21:32
  • 212

JS OO继承、多继承一法

一般原型继承的写法 xxx.prototype = new Base();,但是 new Base 这样的写法怎么能对构造器传入参数呢?明显写死了而不能传入参数——必然要有其他的做法。什么做法?我们很...
  • zhangxin09
  • zhangxin09
  • 2011年03月05日 23:15
  • 4687

javascript oo实现(面向对象)

很久很久以前,我还是个phper,第一次接触javascript觉得好神奇。跟传统的oo类概念差别很大。记得刚毕业面试,如何在javascript里面实现class一直是很热门的面试题,当前面试百度就...
  • Willian1st
  • Willian1st
  • 2016年06月28日 09:20
  • 275

OO的JavaScript

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

JavaScript 定义Class的方式

JavaScript 作为一种简单灵活的语言,随着互联网,智能客户端的发展,变得越来越举重若轻。虽然JS不是一种以类为基础的面向对象的程序设计语言,但是它在模拟像Java和C++这样以类为基础的语言时...
  • cassaba
  • cassaba
  • 2011年11月02日 09:14
  • 4894

OO思想名词解释

复习 OOA、OOD、OOP  OOA   Object-Oriented Analysis:面向对象分析方法   是在一个系统的开发过程中进行了系统业务调查以后,按照面向对象的思想...
  • superdog007
  • superdog007
  • 2015年10月10日 10:48
  • 1386

浅谈OO思想

最近看到公司评级中,大量提到了OO思想,特别是开发,虽对我们运维并未要求,但看到这篇文章不错,就自己理解下。 object oriented(面向,面对)(针对分析,需求分析,功能实现)(面向对象的...
  • bbsyi
  • bbsyi
  • 2016年01月26日 09:47
  • 1846

JavaScript内核系列

  • 2010年05月06日 13:37
  • 1.29MB
  • 下载

SAP ABAP OO ALV 获取当前的alv事件 包括f4帮助,回车按钮,等其他全部按钮alv操作

*   获取当前事件      lv_enter = cl_gui_alv_grid=>CUR_EVENT.
  • forever_crazy
  • forever_crazy
  • 2014年02月14日 15:22
  • 1693
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:OO的JavaScript
举报原因:
原因补充:

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