时间:2021-05-26
本文实例讲述了JS中的继承操作。分享给大家供大家参考,具体如下:
原理:让SuperType的实例成为子类的原型对象,子类的实例拥有了父类的属性和方法。但也有弊端,如果父类的属性是引用类型,这将导致共享的属性被改变的时候,全部的属性将被改变,我们一下代码。
function SuperType() { this.property = [1,2,3]; }SuperType.prototype.getSuperValue = function() { return this.property;}function SubType() { ths.subproperty = false;}SubType.prototype = new SuperType(); // 实现继承SubType.prototype.getSubValue = function() { return this.subproperty;}var instance1 = new SubType();var instance2 = new SubType();instance1.property.push(4);console.log(instance1.property); // [1,2,3,4]console.log(instance2.property); // [1,2,3,4]我们修改一处的实例属性,两个实例的属性都会被修改,因为这个属性是共享的,这也是原型链继承的缺点。
在子类中调用父类的构造函数,每次实例化时都会新建父类的属性放在新实例中,因此每个实例中的属性都是不一样的,改变一个实例的值不会造成另一个实例的值改变。这个继承方式的缺点是方法的定义不能复用。
这个方法将原型链继承和构造函数继承结合到一起,融合了他们各自的优点。
function SuperType(name) { this.name = name; this.colors = ["red","blue","green"]}SuperType.prototype.sayName = function() { console.log(this.name);}function SubType(name,age) { SuperType.call(this,name); this.age = age;}SubType.prototype = new SuperType();SubType.prototype.constructor = SubType;SubType.prototype.sayAge = function() { console.log(this.age);}var instance1 = new SubType("Nicholas", 29);var instance2 =new SubType("Greg", 27);instance1.colors.push("black");console.log(instance1.colors); // red,blue,green,blackconsole.log(instance2.colors); // red,blue,greeninstance1.sayName(); // Nicholasinstance2.sayName(); // Greginstance1.sayAge(); // 29instance2.sayAge(); // 27ES6中可以通过class创建对象,通过关键字extends继承。
class Point { constructor(x, y) { this.x = x; this.y = y; }}class ColorPoint extends Point { constructor(x, y, color) { this.color = color; // ReferenceError super(x, y); this.color = color; // 正确 }}在ES6的继承中,子类一定要重写父类的构造函授的方法,否则会报错。
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS实现继承的几种常用方式。分享给大家供大家参考,具体如下:1,原型链继承原型链继承/***优点:*实例是父类的实例也是子类的实例*父类新增原型方
本文实例总结了JavaScript类的继承操作。分享给大家供大家参考,具体如下:一、类式继承首先要做的是创建构造函数。按惯例,其名称就是类名,首字母应该大写。在
本文实例讲述了JS函数进阶之继承用法。分享给大家供大家参考,具体如下:直接代码,不解释:js函数继承进阶functionperson(name,age){//对
JS继承JavaScript中没有类的概念,与类相关的继承的概念更是无从谈起,但是我们可以通过特殊的语法来模拟面向对象语言中的继承。在JS中模拟继承有多种方式,
前言JS作为面向对象的弱类型语言,继承也是其非常强大的特性之一。那么如何在JS中实现继承呢?让我们拭目以待。JS继承的实现方式既然要实现继承,那么首先我们得有一