返回顶部
首页 > 资讯 > 精选 >JavaScript组合继承的示例分析
  • 941
分享到

JavaScript组合继承的示例分析

2023-06-25 12:06:12 941人浏览 独家记忆
摘要

这篇文章主要为大家展示了“javascript组合继承的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript组合继承的示例分析”这篇文章吧。原型链继承父类实例作为子类的原型

这篇文章主要为大家展示了“javascript组合继承的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript组合继承的示例分析”这篇文章吧。

原型链继承

父类实例作为子类的原型
子类创造的两个实例的隐式原型__proto__指向父类的那个实例
而父类的实例的隐式原型__proto__又指向父类的原型father.prototype
根据原型链的特性,所有子类的实例能够继承父类原型上的属性。

阅览以下这张图可以配合代码理解清晰:

JavaScript组合继承的示例分析

 //父类    function father() {      this.fatherAttr = ["fatherAttr"];    }        //父类的原型上的属性    father.prototype.checkProto = "checkProto";    //子类    function child() {}    // 将father实例作为child这个构造函数的原型    child.prototype = new father();    child.prototype.constructor = child;    //两个子类实例    const test1 = new child();    const test2 = new child();    console.log("测试1:");    console.log("test1:", test1);    console.log("test2:", test2);    console.log("test1.fatherAttr:", test1.fatherAttr);    console.log("test2.fatherAttr:", test2.fatherAttr);    console.log("测试2:");    test1.fatherAttr.push("newAttr");    console.log("test1.fatherAttr:", test1.fatherAttr);    console.log("test2.fatherAttr:", test2.fatherAttr);    console.log("测试3:");    console.log("test1.checkProto:", test1.checkProto);

JavaScript组合继承的示例分析

特点:

  • 两个实例对象都没有fatherAttr属性,但是因为父类的实例会拥有fatherAttr属性,且现在父类的实例作为child的原型,根据原型链,他们可以共享到自己的构造函数child的原型上的属性。(测试1)

  • 因为只有一个父类的实例作为他们的原型,所以所有实例共享了一个原型上的属性fatherAttr,当原型上的属性作为引用类型时,此处是数组test1添加一个新内容会导致test2上的fatherAttr也改变了。(测试2)(缺点)

  • child构造函数不能传递入参。(缺点)

  • 实例可以访问到父类的原型上的属性,因此可以把可复用方法定义在父类原型上。(测试3)

构造函数继承

将父类上的this绑定到子类,也就是当子类创造实例时会在子类内部调用父类的构造函数,父类上的属性会拷贝到子类实例上,所以实例会继承这些属性。

//父类    function father(params) {      this.fatherAttr = ["fatherAttr"];      this.params = params;    }    //父类的原型上的属性    father.prototype.checkProto = "checkProto";    //子类    function child(params) {      father.call(this, params);    }    //两个子类实例    const test1 = new child("params1");    const test2 = new child("params2");    console.log("测试1:");    console.log("test1:", test1);    console.log("test2:", test2);    console.log("test1.fatherAttr:", test1.fatherAttr);    console.log("test2.fatherAttr:", test2.fatherAttr);    console.log("测试2:");    test1.fatherAttr.push("newAttr");    console.log("test1.fatherAttr:", test1.fatherAttr);    console.log("test2.fatherAttr:", test2.fatherAttr);        console.log("测试3:");    console.log("test1.checkProto:", test1.checkProto);

JavaScript组合继承的示例分析

特点:

  • 两个实例对象都拥有了拷贝来的fatherAttr属性,所以没有共享属性,创造一个实例就得拷贝一次父类的所有属性,且因为不能继承父类原型,所以方法不能复用,被迫拷贝方法。(测试1)(缺点)

  • test1添加一个新内容只是改变了test1自己的属性,不会影响到test2。(测试2)

  • child构造函数可以传递参数,定制自己的属性。(测试1)

  • 实例不能继承父类的原型上的属性。(测试3)(缺点

组合继承

结合原型链继承和构造函数继承,可以根据两种继承特点进行使用。

  //父类    function father(params) {      this.fatherAttr = ["fatherAttr"];      this.params = params;    }    //父类的原型上的属性    father.prototype.checkProto = "checkProto";    //子类    function child(params) {      //第二次调用了父类构造函数      father.call(this, params);    }    // 将father实例作为child构造函数的原型    child.prototype = new father();//第一次调用了父类构造函数    child.prototype.constructor = child;    //两个实例    const test1 = new child("params1");//从这里跳转去子类构造函数第二次调用了父类构造函数    const test2 = new child("params2");    console.log("测试1:");    console.log("test1:", test1);    console.log("test2:", test2);    console.log("test1.fatherAttr:", test1.fatherAttr);    console.log("test2.fatherAttr:", test2.fatherAttr);    console.log("测试2:");    test1.fatherAttr.push("newAttr");    console.log("test1.fatherAttr:", test1.fatherAttr);    console.log("test2.fatherAttr:", test2.fatherAttr);    console.log("测试3:");    console.log("test1.checkProto:", test1.checkProto);    console.log("测试4:");    delete test1.fatherAttr    console.log("test1:", test1);    console.log("test1.fatherAttr:", test1.fatherAttr);

JavaScript组合继承的示例分析

特点:

  • 两个实例对象都拥有了拷贝来的fatherAttr属性,创造一个实例就得拷贝一次父类的所有属性(构造函数继承特点,测试1),但是能访问父类原型,可以把复用方法定义在父类原型上。(原型链继承特点,测试1)

  • test1添加一个新内容只是改变了test1自己的属性,不会影响到test2。(构造函数继承特点,测试2)

  • child构造函数可以传递参数,定制自己的属性。(构造函数继承特点,测试1)

  • 实例能继承父类的原型上的属性。(原型链继承特点,测试3)

  • 调用了两次父类的构造函数,生成两份实例,创建子类原型链一次,用子类创建实例时,子类内部里面一次,第二次覆盖了第一次。(缺点)

  • 因为调用两次父类构造函数,如果用delete删除实例上拷贝来的fatherAttr属性,实例仍然拥有隐式原型指向的父类实例上的fatherAttr属性。(原型链继承特点,测试4)(缺点)

以上是“JavaScript组合继承的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: JavaScript组合继承的示例分析

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

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

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

  • 微信公众号

  • 商务合作