广告
返回顶部
首页 > 资讯 > 精选 >javascript中实现继承的示例分析
  • 560
分享到

javascript中实现继承的示例分析

2023-06-27 10:06:58 560人浏览 安东尼
摘要

小编给大家分享一下javascript中实现继承的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!类式继承//声明父类//声明父类function SuperClass() { &nbs

小编给大家分享一下javascript中实现继承的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

类式继承

//声明父类//声明父类function SuperClass() {  this.superValue = true;}//为父类添加共有方法SuperClass.prototype.getSuperValue = function () {  return this.superValue;};//声明子类function SubClass() {  this.subValue = false;}//继承父类SubClass.prototype = new SuperClass();//为子类添加共有方法SubClass.prototype.getSubValue = function () {  return this.subValue;};var instance = new SubClass();console.log(instance.getSuperValue()); //trueconsole.log(instance.getSubValue()); //false
类式继承需要将父类的实例赋值给子类原型, subClass.prototype 继承了 superClass。这种类式继承有两个缺点。其一,由于子类通过原型 prototype 对父类实例化,继承了父类,父类中的共有属性要是引用类型,就会在子类中被所有实例共用,因此一个子类的实例更改子类原型从父类构造函数中继承来的共有属性就会直接影响到其他子类,如下:
function SuperClass() {    this.courses = ['语文', '数学', '英语']}function SubClass() {}SubClass.prototype = new SuperClass();var instance1 = new SubClass()var instance2 = new SubClass()console.log(instance2.courses) //['语文', '数学', '英语']instance1.courses.push('化学')console.log(instance2.courses) //['语文', '数学', '英语', '化学']
instance1 的修改直接影响了 instance2,这是一个灾难的陷阱。其二,由于子类实现的继承是靠其原型 prototype 对父类的实例化实现的,因此在创建父类的时候,是无法向父类传递参数的,因而在实例化父类的时候也无法对父类构造函数内的属性进行初始化。如何解决这个问题?请继续往下看。

构造函数继承

function SuperClass(current) {  this.courses = ["语文", "数学", "英语"];  this.current = current;}//父类声明原型方法SuperClass.prototype.getCourses= function () {  console.log(this.courses);};//声明子类function SubClass(current) {  SuperClass.call(this, current);}var instance1 = new SubClass("语文");var instance2 = new SubClass("数学");instance1.courses.push('化学')console.log(instance1.courses); //["语文", "数学", "英语", "化学"]console.log(instance1.current); //语文console.log(instance2.courses); //["语文", "数学", "英语"]console.log(instance2.current); //数学instance1.getCourses() //TypeError: instance1.getCourses is not a function
SuperClass.call(this, current) 这条语句是构造函数继承的精华。由于 call 这个方法可以更改函数的作用环境,因此在子类中,对 SuperClass 调用这个 call 就是将子类中变量在父类中执行一遍,由于父类中是给 this 绑定属性的,因此子类也就继承了父类的共有属性。由于这种类型的继承没有涉及原型 prototype,所以父类的的原型方法不会被子类继承,要想被子类继承,只能将 showCourse 放在父类构造函数中,但是这样就违背了代码复用的原则。为了综合以上两种继承的优点,于是有了组合继承。

组合继承

//组合继承function SuperClass(current) {  //引用类型共有属性  this.courses = ["语文", "数学", "英语"];  // 值类型共有属性  this.current = current;}SuperClass.prototype.getCourses = function () {  console.log(this.courses);};SuperClass.prototype.getCurrent = function () {  console.log(this.current);};// 声明子类function SubClass(current, time) {  //构造函数继承父类属性  SuperClass.call(this, current);  this.time = time;}//类式继承 子类原型继承父类SubClass.prototype = new SuperClass();//子类原型方法SubClass.prototype.getTime = function () {  console.log(this.time);};
在子类构造函数中执行父类构造函数,在子类的原型上实例化父类就是组合模式,子类实例中更改父类继承下来的引用类型属性 courses 不会改变其他实例,测试如下
var instance1 = new SubClass("语文", "9:00");instance1.getTime(); //9:00instance1.courses.push('化学')instance1.getCourses(); //["语文", "数学", "英语", "化学"]instance1.getCurrent(); //语文console.log(instance1.current)//语文var instance2 = new SubClass("数学", "10:00");instance2.getTime(); //10:00instance2.getCourses(); //["语文", "数学", "英语"]instance2.getCurrent(); //数学console.log(instance2.current)//数学
但是该模式在执行子类构造函数时执行了一遍父类函数,在实现子类原型继承时又执行了一遍父类构造函数,调用了父类构造函数两遍,显然是一个设计缺陷,那还有更好的方式吗?针对该缺陷,出现了“寄生组合式继承”

寄生组合式继承

在介绍这种继承方式之前,需要先了解 “原型式继承”和“寄生式继承”

基础了解

原型式继承

function inheritObject(o) {  function F() {}  F.prototype = o;  return new F();}var course = {  name: "语文",  alikeCourse: ["数学", "英语"],};var newCourse = inheritObject(course);newCourse.name = "化学";newCourse.alikeCourse.push("物理");var otherCourse = inheritObject(course);otherCourse.name = "政治";otherCourse.alikeCourse.push("历史");console.log(newCourse.name); //化学console.log(newCourse.alikeCourse); //["数学", "英语", "物理", "历史"]console.log(otherCourse.name); //政治console.log(otherCourse.alikeCourse); //["数学", "英语", "物理", "历史"]console.log(course.name); //语文console.log(course.alikeCourse); //["数学", "英语", "物理", "历史"]
inheritObject 可以看做是对类式继承的一种封装,其中的过度类 F 相当于类式继承中的子类。在类式继承中存在的共用引用类型的问题依然存在,但是过度类 F 构造函数中无内容,所以开销较小。

寄生式继承

“寄生式继承”是在“原型式继承”的基础上继续增强。
function inheritObject(o) {  function F() {}  F.prototype = o;  return new F();}var course = {  name: "语文",  alikeCourse: ["数学", "英语"],};function createCourse(obj) {  //通过原型继承方式创建新对象  var o = new inheritObject(obj);  // 拓展新对象  o.getName = function () {    console.log(this.name);  };  return o;}const newCourse = createCourse(course)
这种方式在某个对象内部持续增长属性,像寄生式生长,所以称之为寄生继承。寄生继承是对原型继承的二次封装,并且在二次封装的过程中对继承的对象做了拓展,这样新创建的对象不仅仅有父类中的属性和方法,而且还添加了新的属性和方法。在这种思想的基础上,结合组合式继承,衍生了 “寄生组合式继承”

实现

function inheritObject(o) {    function F() {}    F.prototype = o;    return new F();  }function inheritPrototype(subClass, superClass) {    //复制一份父类的原型副本保存在变量中    var p = inheritObject(superClass.prototype)    //修正因为重写子类原型导致子类的constructor属性被修改    p.constructor = subClass    //设置子类的原型    subClass.prototype = p}
以上父类原型保存一个副本,赋值给子类原型,从而实现继承,且并未重新调用一次父类函数,测试如下,与组合继承模式相近
//testfunction SuperClass(current) {  //引用类型共有属性  this.courses = ["语文", "数学", "英语"];  // 值类型共有属性  this.current = current;}SuperClass.prototype.getCourses = function () {  console.log(this.courses);};SuperClass.prototype.getCurrent = function () {  console.log(this.current);};// 声明子类function SubClass(current, time) {  //构造函数继承父类属性  SuperClass.call(this, current);  this.time = time;}//寄生式继承 子类原型继承父类inheritPrototype(SubClass, SuperClass);//类式继承 子类原型继承父类// SubClass.prototype = new SuperClass();//子类原型方法SubClass.prototype.getTime = function () {  console.log(this.time);};var instance1 = new SubClass("语文", "9:00");var instance2 = new SubClass("数学", "10:00");instance1.getTime(); //9:00instance1.courses.push("化学");instance1.getCourses(); //["语文", "数学", "英语", "化学"]instance1.getCurrent(); //语文console.log(instance1.current); //语文instance2.getTime(); //10:00instance2.getCourses(); //["语文", "数学", "英语"]instance2.getCurrent(); //数学console.log(instance2.current); //数学

区别仅在

//寄生式继承 子类原型继承父类inheritPrototype(SubClass, SuperClass);//类式继承 子类原型继承父类// SubClass.prototype = new SuperClass();
从而实现多个子类多个实例不相互影响,父类构造函数仅仅调用一次,堪当 JavaScript 继承的终极模式。

看完了这篇文章,相信你对“javascript中实现继承的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: javascript中实现继承的示例分析

本文链接: https://www.lsjlt.com/news/309394.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • javascript中实现继承的示例分析
    小编给大家分享一下javascript中实现继承的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!类式继承//声明父类//声明父类function SuperClass() { &nbs...
    99+
    2023-06-27
  • javascript中继承的示例分析
    这篇文章主要介绍javascript中继承的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!javascript 中的继承实例详解阅读目录原型链继承借用构造函数组合继承寄生组合...
    99+
    2022-10-19
  • JavaScript中继承、封装、多态实现的示例分析
    小编给大家分享一下JavaScript中继承、封装、多态实现的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!面向对象的三...
    99+
    2022-10-19
  • JavaScript原型继承的示例分析
    这篇文章主要介绍JavaScript原型继承的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在传统的基于Class的语言如Java、C++中,继承的本质是扩展一个已有的Cla...
    99+
    2022-10-19
  • JavaScript组合继承的示例分析
    这篇文章主要为大家展示了“JavaScript组合继承的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript组合继承的示例分析”这篇文章吧。原型链继承父类实例作为子类的原型...
    99+
    2023-06-25
  • ES6 javascript中Class类继承的示例分析
    小编给大家分享一下ES6 javascript中Class类继承的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体如下:1. 基本用法Class 之间可以通过extends关键字...
    99+
    2022-10-19
  • js中继承的示例分析
    这篇文章给大家分享的是有关js中继承的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。继承的简介继承”是JavaScript面向对象设计的重要一环,愿你认真读完本文,吃透继...
    99+
    2022-10-19
  • CSS中继承的示例分析
    小编给大家分享一下CSS中继承的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、说明解释   -  ...
    99+
    2022-10-19
  • JavaScript中多种组合继承的示例分析
    这篇文章主要为大家展示了“JavaScript中多种组合继承的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript中多种组合继承的示例分析...
    99+
    2022-10-19
  • Angular.JS中Scope继承的示例分析
    这篇文章主要介绍Angular.JS中Scope继承的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!基本原理在JavaScript中,每创建一个构造函数(constructo...
    99+
    2022-10-19
  • JavaScript原型与继承实例分析
    今天小编给大家分享一下JavaScript原型与继承实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。首先我们需要知道的...
    99+
    2023-06-27
  • c++中继承关系的示例分析
    这篇文章给大家分享的是有关c++中继承关系的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1 什么是继承继承概念继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段,它允许程序...
    99+
    2023-06-20
  • php中有限继承的示例分析
    这篇“php中有限继承的示例分析”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“php中有限继承的示例分析”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起...
    99+
    2023-06-06
  • C++继承方式的示例分析
    这篇文章给大家介绍C++继承方式的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。C++支持多种程序设计风格,其中就包括对面向对象设计的支持。我们今天在这里将会为大家详细介绍一下各种C++继承方式的具体应用方法,...
    99+
    2023-06-17
  • Java的继承实例分析
    这篇文章主要介绍“Java的继承实例分析”,在日常操作中,相信很多人在Java的继承实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的继承实例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧...
    99+
    2023-06-29
  • Kotlin继承实例分析
    本篇内容介绍了“Kotlin继承实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Kotlin中所有的类都有一个公有的超类:Any,这是...
    99+
    2023-06-17
  • PHP中类继承关系的示例分析
    这篇文章将为大家详细讲解有关PHP中类继承关系的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在PHP中,我时常会写一个类,类写了一个共用方法,然后让子类去继承就...
    99+
    2022-10-19
  • css中属性值继承的示例分析
    这篇文章主要介绍了css中属性值继承的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。继承:html元素可以从父元素那里继承一部分cs...
    99+
    2022-10-19
  • CSS中级联和继承的示例分析
    这篇文章主要为大家展示了“CSS中级联和继承的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“CSS中级联和继承的示例分析”这篇文章吧。   1.在HT...
    99+
    2022-10-19
  • Java中继承和多态的示例分析
    这篇文章给大家分享的是有关Java中继承和多态的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言首先我们如果要使用Java中存在的包,可以程序中使用import语句导入包。包说通俗点就是一个文件夹,为了...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作