浏览 1532 次
锁定老帖子 主题:javascript继承方式之一
精华帖 (0) :: 良好帖 (0) :: 新手帖 (10) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-07-11
最后修改:2009-07-11
面向对象的语言多数都支持继承,继承最重要的优点就是代码复用,从而构建大型软件系统。如果一个类能够重用另一个类的属性和或方法,就称之为继承。从这个角度来看看js的继承方式。js中继承方式与写类方式息息相关。不同的写类方式造成不同的继承方式。各种流行js库继承方式也各不相同。从最简单的复用开始。
1、构造函数写类,通过方法调用复制父类属性给子类 实现继承
这里父类,子类都用构造函数方式写,不用原型。子类调用父类函数来复制父类的属性。 /** * 父类Polygon:多边形 * @param {Object} sides */ function Polygon(sides) { this.sides = sides; this.setSides = function(s) {this.sides=s;} } /** * 子类Triangle:三角形 */ function Triangle() { this.tempfun = Polygon;//父类引用赋值给子类的一个属性tempfun this.tempfun(3);//调用 delete this.tempfun;//删除该属性 this.getArea = function(){}; } //new个对象 var tri = new Triangle(); console.log(tri.sides);//继承的属性 console.log(tri.setSides);//继承的方法 console.log(tri.getArea);//自有的方法 //缺点是对于Triangle的实例对象用instanceof为父类Polygon时是false console.log(tri instanceof Triangle);//true console.log(tri instanceof Polygon);//false 因为js具名函数有四种调用方式 ,子类还可以有以下的多种实现方式。只是在子类中调用父类方法不同而已。 function Triangle() { Polygon.call(this,3);//call方式调用父类 this.getArea = function(){}; } function Triangle() { Polygon.apply(this,[3]);//apply方式调用父类 this.getArea = function(){}; } function Triangle() { var temp = new Polygon(3);//new方式调用父类 for(atr in temp)//全部复制给子类 this[atr] = temp[atr]; this.getArea = function(){}; }
这种方式的缺点是子类的实例对象用instanceof检查父类时总是false。这与java中继承"is a "的关系是违背的。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |