JS中的继承方法——组合继承介绍与实践
来源:互联网 发布:淘宝秒抢优惠券抢不到 编辑:程序博客网 时间:2024/05/16 01:55
组合继承是原性链继承和构造函数继承的合体,它汲取了二者各自的有点,同时又互相补充了各自的弱点,是一种应用十分广泛的javascript继承模式。下面分别从原性链继承、构造函数继承分别开始介绍,最后介绍二者的结合——组合继承。
一、原型链:利用原型让一个引用类型继承另一个引用类型的属性和方法
每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。
实现原性链的基本模式:
function SuperType(){ this.property =true;}SuperType.prototype.getSuperValue = function(){ returnthis.property;}function Subtype){ this.subproperty =false;}SubType.prototype = new SuperType(); //实现了继承SuperTypeSubType.prototype.getSubValue = function(){ returnthis.subproperty;}var instance = new SubType();alert(instance.getSuperValue());
最后的结果:intance指向SubType的原型,而SubType的原型又指向SuperType的原型,SuperType继承了Object
所有函数的默认原型都是Object的实例
问题:会产生引用类型值的问题
比如,创建了一个子类的实例,如果对子类实例的属性进行了修改,那么创建其他子类的时候都会收到影响,代码如下:
function SuperType(){ this.colors =[“red”, “blue”, “green”];}function SubType(){}SubType.prototype = new SuperType();var instance1 = new SubType();instance1.colors.push(“black”);alert(instance1.colors); //red, blue, green, blackvar instance2 = new SubType();alert(instance2.colors); //red, blue, green, black
以上结果说明会影响其他实例的属性值
二、借用构造函数:在子类型构造函数的内部调用超类型构造函数
function SuperType(){ this.colors =[“red”, “blue”, “green”];}function SubType{}( SuperType.call(this); //继承了SuperType。通过调用SuperType的构造函数,借用其构造结构}var instance1 = new SubType();instance1.colors.push(“black”);alert(intance1.colors); //red,blue,green,blackvar instance2 = new SubType();alert(instance2.colors); //red,blue,green
使用该方法可以在子类构造函数中向超类型构造函数传递参数,如下:
function SuperType(name){ this.name = name;}function SubType(){SuperType.call(this,“Nicholas”); //传入参数,利用这个参数初始化父类构造函数中的namethis.age = 29;}var instance = new SubType();alert(instance.name); //Nicholasalert(instance.age); //29
问题:不方便复用
三、组合式继承:使用原型链实现对原型属性和方法的继承,而通过借用构造函数来实现对实例属性的继承
示例代码:
function SuperType(name){this.name = name;this.colors = [“red”, “blue”,“green”];}SuperType.prototype.sayName = function(){ //定义了一个方法,该方法在继承的子类中也可以用 alert(this.name);}function SubType(name, age){SuperType.call(this, name); //继承SuperType的一部分,this指SubType,this.age = age; //自己新定义的属性age也可以进行赋值}SubType.prototype = new SuperType(); //利用原型继承,可以使用父类的方法(见原型链继承)SubType.prototype.sayAge = function(){ //定义SubType特有的新方法 alert(this.age);}var instance1 = new SubType(“Martin”, 10);instance1.colors.push(“black”);alert(instance1.colors); //red,blue,green,blackinstance1.sayName(); //Martininstance1.sayAge(); //10var instance2 = new SubType(“Greg”, 27);alert(instance2.colors); //red,blue,greeninstance2.sayName(); //Greginstance2.sayAge(); //27
1 0
- JS中的继承方法——组合继承介绍与实践
- JS继承--组合继承
- Java中的继承与组合
- java中的继承与组合
- Java中的继承与组合
- Java中的继承与组合
- Java中的继承与组合
- Java中的继承与组合
- js继承之-----组合继承
- js继承之组合继承
- js继承中的方法重写
- js中的继承与重写
- js中的原型与继承
- js的组合继承
- 谈谈Java中的继承与组合
- 谈谈Java中的继承与组合
- 关于设计模式中的继承与组合
- 谈谈Java中的继承与组合
- Centos 6 Oracle 12C 超详细安装
- string::substr()和string::Append()
- Python3 venv 创建虚拟环境
- ios字体动态下载
- 含重复字符的字符串的全排列问题(Java)
- JS中的继承方法——组合继承介绍与实践
- 文本框字母小写即时转大写
- LaTeX新人教程,30分钟从完全陌生到基本入门
- 线程间通信:生产线程和消费线程
- Spring 事务管理 随手笔记 心得
- 知道哪个过程用哪个同步信号量
- CentOS 7在grub rescue模式中修复系统
- nat模式下主机ping不通虚拟机解决办法
- 滑动的导航,背景图片或者边框滑动效果