首页 > 编程语言 >JavaScript高级(九)---JavaScript的六种继承方式

JavaScript高级(九)---JavaScript的六种继承方式

时间:2024-03-23 14:00:34浏览次数:27  
标签:function test1 const Sub 六种 JavaScript --- console Super

1、原型继承

实现:

1

2

3

4

5

6

7

function Super(){ this.a=1 }

Super.prototype.say = function(){ console.log(‘hhh') }

function Sub(){}

Sub.prototype = new Super()

const test = new Sub()

console.log( test.say() )// hhh

优点:通过原型继承多个引用类型的属性和方法

缺点:Sub原型变成了Super的实例,如果Super的实例某个属性是引用值,该引用值就会被应用到所有Sub创建的实例中去,会有污染问题。如下

1

2

3

4

5

6

7

8

9

function Super(){ this.a=[1,2] }

function Sub(){}

Sub.prototype = new Super()

const test1 = new Sub()

test1.a.push(3)

console.log(test1.a)// [1,2,3]

const test2 = new Sub()

console.log(test2.a)// [1,2,3]

2、盗用构造函数

实现:构造函数模式+call

1

2

3

4

5

6

7

function Super = function(){ this.a = 1 }

function Sub = function(){

       Super.call(this)

       this.b = 2

}

const test = new Sub()

优点:每个实例都会有自己的a属性,哪怕是引用值也不会被污染

缺点:Super构造函数中的方法在每个实例上都要创建一遍(除非该方法声明提到全局);Sub的实例无法访问Super原型上的方法

3、组合继承

实现:原型继承+盗用构造函数继承

1

2

3

4

5

6

7

8

9

10

11

12

13

14

function Super(){ this.a=[1,2] }

Super.prototype.say = function(){ console.log(‘hhh') }

function Sub(){

    Super.call(this)

    this b=2

}

Sub.prototype = new Super()

  

const test1 = new Sub()

console.log( test1.say() )// hhh

test1.a.push(3)

console.log(test1.a)// [1,2,3]

const test2 = new Sub()

console.log(test2.a)// [1,2]

优点:集合了【原型继承】和【盗用构造函数继承】的优点

缺点:存在效率问题,Super始终会被调用两次

4、原型式继承

实现:

es5之前

1

2

3

4

5

6

7

8

const obj = { a:1 }

function createObj(o){

    const Fn(){}

    Fn.prototype = o

    return new Fn()

}

const test = createObj(obj)

es5之后

1

2

3

const obj = { a:1 }

const test = Object.create(obj)

优点:对一个对象进行浅克隆创建另一个对象,同时继承该对象的原型属性

缺点:由于是浅克隆,所以实例共享的对象属性如果是引用值,会受污染。如下

1

2

3

4

5

6

7

8

const obj = { a:[1,2], b:2 }

const test1 = Object.create(obj)

const test2 = Object.create(obj)

test1.a.push(3)

test1.b=3

console.log(test1.a, test2.a)// [1,2,3]  [1,2,3]

console.log(test1.b, test2.b)// 3 2

5、寄生式继承

实现:构造函数模式+工厂模式

1

2

3

4

5

6

7

8

9

10

function createObj(o){

    let clone = objectCopy(o)

    clone.say=function(){

        console.log(‘hhh')

    }

    return clone

}

const obj = { a:1 }

const test = createObj(obj)

优点:根据一个对象克隆创建另一个对象,并增强对象

缺点:同【盗用构造函数继承】方法在每个实例上都要创建一遍

注意:objectCopy是对入参对象的复制

6、寄生式组合继承

实现:盗用构造函数继承 + 原型式继承

1

2

3

4

5

6

7

8

9

10

11

function Super(){ this.a=[1,2] }

Super.prototype.say = function(){ console.log(‘hhh') }

function Sub(){

    Super.call(this)

    this b=2

}

Sub.prototype = Object.create(Super.prototype)

Sub.prototype.constructor = Sub

const test = new Sub()

优点:集合了【原型式继承】和【盗用构造函数继承】的优点,效率比【组合继承】更高。

标签:function,test1,const,Sub,六种,JavaScript,---,console,Super
From: https://blog.csdn.net/2301_79206800/article/details/136966278

相关文章

  • 应急响应靶机-3
    继续搞第三个靶机看看今天的问题日志里发现了两个Ip192.168.75.129和192.168.75.130发现一些问题这个192.168.75.129似乎一直访问一个cmd.php?act=verify,这个操作是在爆破弱口令登录,但是一直是500意味着它并没有登录成功!但是192.168.75.130似乎做了一些奇怪的操作,它似......
  • 【Java - 框架 - HttpClient】(01) 使用“HttpClient“爬取网页的代码示例 - 快速上手
    使用"HttpClient"爬取网页的代码示例-快速上手;依赖<dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpcore</artifactId><version>4.4.14</version></dependency><dependency>......
  • 【Java - 框架 - Knife4j】(01) SpringBoot整合Knife4j - 快速上手
    “SpringBoot"整合"Knife4j”-快速上手;环境“Knife4j"版本"2.0.9”;“Java"版本"1.8.0_202”;“SpringBoot"版本"2.5.9”;“Windows11专业版_22621.2428”;“IntelliJIDEA2021.1.3(UltimateEdition)”;步骤步骤A说明创建"SpringBoot"项目;图片(1)......
  • 腾讯视频号直播卖货学习第二十课-IP起号注意事项
    IP号直播需要有长期经营视角1养号阶段避免短视频挂车,因为挂车后会影响短视频质量2注重GPM,不要盲目追求单场GMV或UV【过渡消费粉丝】3封面直播间内容形式做立体人设,多样化,拉长用户新鲜度4宁投流不刷单减少手续费空耗,弄坏直播间模型标签IP账户投放配合品牌/IP较弱,预......
  • ETL工具-nifi干货系列 第一讲 揭开nifi神秘面纱
    1、nifi简介ApacheNiFi是基于流程编程概念的数据流系统。它支持强大且可扩展的数据路由、转换和系统中介逻辑的有向图。NiFi具有基于Web的用户界面,用于设计、控制、反馈和监控数据流。它在多个服务质量维度上都具有高度可配置性,例如容忍丢失与保证传递、低延迟与高吞吐量、基于......
  • 使用Django-Simple-Captcha在Django项目加入验证码模块并自定义样式
    在Django项目中加入验证码功能,通常需要借助第三方库,比如Django-Smple-Captch、Django-reCAPTCHA、DEF-reCAPTCHA、Wagtail-Django-ReCaptcha、Django-Friendly-Captcha等。其中,Django-Smple-Captcha是一个流行的选择,它提供了一个简单而强大的Django应用,无需调用第三方API,......
  • 文件上传一-WEB攻防-PHP应用&文件上传&函数缺陷&条件竞争&二次渲染&黑白名单&JS绕过9
    演示案例:PHP-原生态-文件上传-前后端验证PHP-原生态-文件上传-类型文件头验证PHP-原生态-文件上传-后缀黑白名单验证PHP-原生态-文件上传-解析配置&二次渲染PHP-原生态-文件上传-逻辑缺陷&函数缺陷#学习前必读:1、课前一定要明白:无文件解析安全问题上,格式解析是一......
  • 数据库面试高频题目 - 深度解析 MySQL:探秘关系型数据库的核心技术(一)
       本文将深入探讨MySQL,这是关系型数据库中的核心技术,被广泛应用于数据存储和管理。透过高频面试题解析,我们将深入研究MySQL在数据建模、查询优化和事务处理中的作用。无论你是初学者还是渴望加深对关系型数据库技术的了解,本文都将为你提供实用的面试准备。一、innod......
  • 【华为OD】2024年C卷真题集:最新的真题集题库 C/C++/Java/python/JavaScript
    2024年C卷真题题集题库,有2种分数的题目列表,分别是100分的列表、200分的列表需要订阅请看链接:C卷100分真题集质量分:94价格:39.9元C卷200分真题集质量分:94价格:99.9元从2023年11月开始,华为OD题目切换到C卷,基本上大概率会使用半年左右,要在2024年5月之前把这些题目都好好练习一下......
  • 【数据分享】2008-2022年全国范围逐日NO2栅格数据
    空气质量数据是在我们日常研究中经常使用的数据!之前我们给大家分享了2000-2022年全国范围逐日的PM2.5栅格数据、2013-2022年全国范围逐日SO2栅格数据、2000-2022年全国范围逐日PM10栅格数据、2013-2022年全国范围逐日CO栅格数据和2000-2022年全国1km分辨率的逐日O3栅格数据(可查......