加载中…
个人资料
小僧怀静
小僧怀静 新浪个人认证
  • 博客等级:
  • 博客积分:0
  • 博客访问:4,851
  • 关注人气:15
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
相关博文
推荐博文
谁看过这篇博文
加载中…
正文 字体大小:

关于JS继承

(2010-11-16 13:42:30)
标签:

it

分类: javascript

众所周知,Js是若变量语言。众所周知,面向对象编程给我们带来的好处。

下面,用最简单的例子讲解一下JS继承方面的问题。

问题很简单,我们生活中常见种形状有包括三角形和矩形,下面的方法是三角形和矩形灵活继承形状的例子:

 

 

 

function Xingzhuang(sides)
{
 this.sides=sides;
}
Xingzhuang.prototype.getArea=function()
{
 return 0;  //返回0以方便子类对面积计算方法的覆盖
}

 

//创建三角形子类,加入自己的私有属性【底、高】
function San(ibase,iheight)
{

 Xingzhuang.call(this,3)     //通过call继承形状父类,获取父类sides属性
 this.ibase=ibase;
 this.iheight=iheight;
}
San.prototype=new Xingzhuang();    //通过原型链继承父类
San.prototype.getArea=function()     //覆盖父类的面积计算公式
{
 return this.ibase*this.iheight*0.5;
}

//创建矩形子类,加入自己的私有属性【长、宽】

function Juxing(iLength,iWidth)
{
 Xingzhuang.call(this,4)     //通过call继承形状父类,获取父类sides属性
 this.iLength=iLength;
 this.iWidth=iWidth;
}

Juxing.prototype=new Xingzhuang()    //通过原型链继承父类
Juxing.prototype.getArea=function()    //覆盖父类的面积计算公式
{
 return this.iLength*this.iWidth;
}

 

//测试:

var san1=new San(4,5);

alert(san1.sides);
alert(san1.getArea());

 

var Jx1=new Juxing(4,5);
alert(Jx1.sides);
alert(Jx1.getArea())

0

阅读 评论 收藏 转载 喜欢 打印举报/Report
  • 评论加载中,请稍候...
发评论

    发评论

    以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

      

    新浪BLOG意见反馈留言板 电话:4000520066 提示音后按1键(按当地市话标准计费) 欢迎批评指正

    新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 会员注册 | 产品答疑

    新浪公司 版权所有