Javascript组合继承方法代码实例解析


Posted in Javascript onApril 02, 2020

Javascript组合继承方法代码实例解析

组合继承

组合继承,指将原型链和借用构造函数的技术组合到一块,从而发挥二者之长的一种继承模式。其背后思路使用用原型链实现对原型属性和方法的继承,而通过构造函数来实现对实例属性的继承。这样,即通过在原型上定义方法实现了函数复用,又能够保证每个实例都有它自己的属性。

下面来看一个例子

function SuperType(name) {
  this.name = name;
  this.color = ['red', 'blue', 'green'];
};
//
SuperType.prototype.sayName = function() {
  console.log(this.name);
};
//
function SubType(name, age) {
  //继承属性
  SuperType.call(this, name);		// 第二次调用SuperType
//
  this.age = age;
};
//继承方法
SubType.prototype = new SuperType();	// 第一次调用SuperType
console.log(SubType.prototype.constructor); //输出SuperType函数的源码,即此时SubType.prototype.constructor指向SuperType函数
SubType.prototype.constructor = SubType; //将SubType.prototype.constructor指针指回SubType函数
SubType.prototype.sayAge = function() {
  console.log(this.age);
};
//
var instance1 = new SubType('Jake', 20)
instance1.color.push('black');
console.log(instance1.color); //'red,blue,green,black'
instance1.sayName(); //'Jake'
instance1.sayAge(); //20
//
var instance2 = new SubType('Greg', 21);
console.log(instance2.color); //'red,blue,green'
instance2.sayName(); //'Greg';
instance2.sayAge(); //21

观察输出结果,便可以发现:两个SubType实例(instance1和instance2)既分别有自己的属性,又可以使用相同的方法。

优点

组合继承避免了原型链和借用构造函数的缺陷,融合了它们的优点,所以是JS中最常用的继承模式。而且,instanceof和isPrototypeOf()也能够用于识别基于组合继承创建的对象。

缺点

调用两次SuperType构造函数

在SubType.prototype上创建了不必要的属性

寄生组合继承

function SuperType (name) {
 this.name = name
 this.colors = ['red', 'blue', 'yellow']
}

SuperType.prototype.sayName = function () {
 console.log(this.name)
}

function SubType (name, age) {
 SuperType.call(this, name) // 通过构造函数继承实例属性
 this.age = age
}

SubType.prototype = Object.create(SuperType.prototype)	//继承父类共享方法
SubType.prototype.constructor = SubType	//将SubType.prototype.constructor指针指回SubType函数
SubType.prototype.sayAge = function () {
 console.log(this.age)
}

let obj = new SubType('jake', 22)
obj.sayName()	// jake
obj.sayAge()	// 22
console.log(obj instanceof SubType)	// true
console.log(obj instanceof SuperType)	// true

优点

寄生组合继承只调用了一次SuperType,所以更高效

避免了在SubType.prototype上创建了不必要的属性

下面说说原型链和构造函数的缺点

原型链

缺点:当原型链中包含引用类型值时,原型属性会被所有实例共享;

下面看一个例子

function SuperType() {
  this.color = ['red', 'blue', 'green'];
}
//
function SubType() {};
//
SubType.prototype = new SuperType(); //继承了SuperType
//
var instance1 = new SubType();
instance1.color.push('black');
console.log(instance1.color);  //'red,blue,green,black'
//
var instance2 = new SubType();
console.log(instance2.color);  //'red,blue,green,black'

借用构造函数

缺点:如果仅仅使用构造函数,方法都在构造函数中定义,因此函数就无法实现复用了。而且,在超类型的原型中定义的方法,对于子类型而言也是不可见的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 模拟气泡屏保效果代码
Jul 10 Javascript
鼠标拖动实现DIV排序示例代码
Oct 14 Javascript
javascript中使用正则计算中文长度的例子
Apr 29 Javascript
JQuery判断radio(单选框)是否选中和获取选中值方法总结
Apr 15 Javascript
javascript属性访问表达式用法分析
Apr 25 Javascript
JavaScript编程的单例设计模讲解
Nov 10 Javascript
AngularJs Javascript MVC 框架
Jun 20 Javascript
原生js轮播特效
May 18 Javascript
vue配置font-awesome5的方法步骤
Jan 27 Javascript
详解基于原生JS验证表单组件xy-form
Aug 20 Javascript
JS数组降维的实现Array.prototype.concat.apply([], arr)
Apr 28 Javascript
Vue项目开发常见问题和解决方案总结
Sep 11 Javascript
Javascript异步编程async实现过程详解
Apr 02 #Javascript
JS实现图片懒加载(lazyload)过程详解
Apr 02 #Javascript
JavaScript运动原理基础知识详解
Apr 02 #Javascript
基于js实现逐步显示文字输出代码实例
Apr 02 #Javascript
webpack3.0升级4.0的方法步骤
Apr 02 #Javascript
Javascript模块化机制实现原理详解
Apr 02 #Javascript
sharp.js安装过程中遇到的问题总结
Apr 02 #Javascript
You might like
理解和运用PHP中的多态性[译]
2011/08/02 PHP
PHP生成等比缩略图类和自定义函数分享
2014/06/25 PHP
php实现的常见排序算法汇总
2014/09/08 PHP
Yii中使用PHPExcel导出Excel的方法
2014/12/26 PHP
php通过function_exists检测函数是否存在的方法
2015/03/18 PHP
求解开jscript.encode代码的asp函数
2007/02/28 Javascript
向fckeditor编辑器插入指定代码的方法
2007/05/25 Javascript
javascript 日期时间函数(经典+完善+实用)
2009/05/27 Javascript
单击浏览器右上角的X关闭窗口弹出提示的小例子
2013/06/12 Javascript
Extjs Label的 fieldLabel和html属性值对齐的方法
2014/06/15 Javascript
JS右下角广告窗口代码(可收缩、展开及关闭)
2015/09/04 Javascript
input点击后placeholder中的提示消息消失
2016/01/15 Javascript
JavaScript中清空数组的方法总结
2016/12/02 Javascript
Vue的MVVM实现方法
2017/08/16 Javascript
jQuery实现的粘性滚动导航栏效果实例【附源码下载】
2017/10/19 jQuery
vue源码学习之Object.defineProperty 对数组监听
2018/05/30 Javascript
webpack4.0 入门实践教程
2018/10/08 Javascript
puppeteer实现html截图的示例代码
2019/01/10 Javascript
Vue指令指令大全
2019/02/09 Javascript
js定时器出现第一次延迟的原因及解决方法
2021/01/04 Javascript
[02:47]3.19DOTA2发布会 国服成长历程回顾
2014/03/25 DOTA
python网络编程学习笔记(七):HTML和XHTML解析(HTMLParser、BeautifulSoup)
2014/06/09 Python
Python对列表排序的方法实例分析
2015/05/16 Python
python实现ping的方法
2015/07/06 Python
python按综合、销量排序抓取100页的淘宝商品列表信息
2018/02/24 Python
初次部署django+gunicorn+nginx的方法步骤
2019/09/11 Python
利用pandas将非数值数据转换成数值的方式
2019/12/18 Python
Schecker荷兰:狗狗用品和配件
2019/06/06 全球购物
金融专业毕业生推荐信
2013/11/26 职场文书
正风肃纪剖析材料
2014/02/18 职场文书
工作说明书格式
2014/07/29 职场文书
死亡证明书样本说明
2014/10/18 职场文书
电力培训学习心得体会
2016/01/11 职场文书
《圆明园的毁灭》教学反思
2016/02/16 职场文书
导游词之嵊泗列岛
2019/10/30 职场文书
python缺失值的解决方法总结
2021/06/09 Python