JavaScript 基础:继承
栏目: JavaScript · 发布时间: 5年前
内容简介:今天,我们要讲的是 JS 继承的知识,包括 原型继承, 构造函数继承, 组合继承及其优化, 寄生式组合继承。子类的原型对象设置为父类的实例:这样:每个子类实例就会继承父类实例的属性,但由于继承的属性在子类的原型上,所以继承的属性在不同实例之间都是共享的,没有隔离。
今天,我们要讲的是 JS 继承的知识,包括 原型继承, 构造函数继承, 组合继承及其优化, 寄生式组合继承。
原型继承
子类的原型对象设置为父类的实例:
function C1 (){} function C2 (){} C2.prototype = new C1(); C2.prototype.constructor = C2;
这样:每个子类实例就会继承父类实例的属性,但由于继承的属性在子类的原型上,所以继承的属性在不同实例之间都是共享的,没有隔离。
构造函数继承
子类的构造函数内部,执行了父类的构造函数:
function C1 (){} function C2 (...args){ C1.call(this, ...args); }
这样:每个子类实例的继承属性就隔离了,但继承不到父类的原型方法;
组合继承
结合以上两种
function C1 (){} function C2 (...args){ C1.call(this, ...args); } C2.prototype = new C1(); C2.prototype.constructor = C2;
这样:继承的私有属性隔离,继承的原型方法可以公用,但是执行了两次父类的构造函数,第二次是多余的。
组合继承优化
结合前两种方法,但把子类的原型对象指向父类的原型对象,而不是实例。
function C1 (){} function C2 (...args){ C1.call(this, ...args); } C2.prototype = C1.prototype; C2.prototype.constructor = C2;
这样:就避免执行了两次父类的构造函数,但破坏了父类的原型对象的 constructor
: C1.proptotype.constructor
,本来应该指向 C1 的,现在指向 C2 了。
寄生组合继承
将子类的原型对象设置为一个新的对象,该对象的 __proto__
指向父类的原型。
function C1 (){} function C2 (...args){ C1.call(this, ...args); } C2.prototype = Object.create(C1.prototype); C2.prototype.constructor = C2;
这样就完美了!
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Java基础知识:继承
- 零基础学习 Python 之继承
- 基础学习 - 在JS 中的继承
- Java 基础 (16):一个例子弄懂什么叫继承?
- java基础(二)-----java的三大特性之继承
- Python语法基础之初始化函数和类的继承
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
JavaScript面向对象编程指南
斯托扬 / 凌杰 / 人民邮电出版社 / 2013-3 / 59.00元
《JavaScript面向对象编程指南》内容包括:JavaScript作为一门浏览器语言的核心思想;面向对象编程的基础知识及其在JavaScript中的运用;数据类型、操作符以及流程控制语句;函数、闭包、对象和原型等概念,以代码重用为目的的继承模式;BOM、DOM、浏览器事件、AJAX和JSON;如何实现JavaScript中缺失的面向对象特性,如对象的私有成员与私有方法;如何应用适当的编程模式,......一起来看看 《JavaScript面向对象编程指南》 这本书的介绍吧!