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 相关文章推荐
网站上面有这种切换效果
Jun 26 Javascript
JS Timing
Apr 21 Javascript
JavaScript中使用正则匹配多条,且获取每条中的分组数据
Nov 30 Javascript
jQuery中element选择器用法实例
Dec 29 Javascript
jquery根据一个值来选中select下的option实例代码
Aug 29 Javascript
jQuery插件HighCharts绘制2D饼图效果示例【附demo源码下载】
Mar 21 jQuery
详解vue.js全局组件和局部组件
Apr 10 Javascript
利用 spin.js 生成等待效果(js 等待效果)
Jun 25 Javascript
基于zepto.js实现登录界面
Oct 09 Javascript
vue源码解析之事件机制原理
Apr 21 Javascript
mpvue将vue项目转换为小程序
Sep 30 Javascript
react中的DOM操作实现
Jun 30 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调用Oracle存储过程的方法
2008/09/12 PHP
php 格式化数字的时候注意数字的范围
2010/04/13 PHP
PHP使用PDO、mysqli扩展实现与数据库交互操作详解
2019/07/20 PHP
利用JQuery为搜索栏增加tag提示
2009/06/22 Javascript
IE与firefox下Dhtml的一些区别小结
2009/12/02 Javascript
当鼠标移动时出现特效的JQuery代码
2013/11/08 Javascript
Jquery实现侧边栏跟随滚动条固定(兼容IE6)
2014/04/02 Javascript
js求数组中全部数字可拼接出的最大整数示例代码
2017/08/25 Javascript
AngularJS实现的输入框字数限制提醒功能示例
2017/10/26 Javascript
Vue项目中如何使用Axios封装http请求详解
2019/10/23 Javascript
Vue 3.0 全家桶抢先体验
2020/04/28 Javascript
[08:44]和酒神一起战斗 DOTA2教你做大人
2014/03/27 DOTA
Python中Continue语句的用法的举例详解
2015/05/14 Python
Django的信号机制详解
2017/05/05 Python
python中nan与inf转为特定数字方法示例
2017/05/11 Python
python-docx修改已存在的Word文档的表格的字体格式方法
2018/05/08 Python
详解django的serializer序列化model几种方法
2018/10/16 Python
python版大富翁源代码分享
2018/11/19 Python
一文秒懂python读写csv xml json文件各种骚操作
2019/07/04 Python
python实现中文文本分句的例子
2019/07/15 Python
python多线程同步实例教程
2019/08/11 Python
Python单元测试与测试用例简析
2019/11/09 Python
基于python的列表list和集合set操作
2019/11/24 Python
python批量修改xml属性的实现方式
2020/03/05 Python
详解Python设计模式之策略模式
2020/06/15 Python
Html5 FileReader实现即时上传图片功能实例代码
2014/09/01 HTML / CSS
经济实惠的豪华背包和行李袋:Packs Project
2018/10/17 全球购物
幼师专业求职推荐信
2013/11/08 职场文书
工地门卫岗位职责
2013/12/30 职场文书
年度考核自我鉴定
2014/02/02 职场文书
《小壁虎借尾巴》教学反思
2014/02/16 职场文书
企业党员公开承诺书
2014/03/26 职场文书
工伤事故赔偿协议书范文
2014/09/24 职场文书
有关信念的名言语录集锦
2019/12/06 职场文书
Python如何导出导入所有依赖包详解
2021/06/08 Python
python脚本框架webpy模板赋值实现
2021/11/20 Python