美文网首页
JS类的创建与继承

JS类的创建与继承

作者: 蓝蓝红同学 | 来源:发表于2021-09-02 11:29 被阅读0次

一、类的创建

JS中,类的创建方式与函数的创建方式相同,主要区别在于一般我们创建类时,类名的首字母需要大写,同时,我们可以再类的原型上添加公共属性和方法。创建例子如下:

构造函数,原型上的属性和的方法可以被调用构造函数的普通对象调用

二、类的继承

    JS类的继承主要有6种方式:原型链继承、实例继承、组合继承、原型式继承、寄生继承、寄生组合继承

1.原型链继承

    创建空的子函数,再子函数的原型上执行构造函数,让子函数的原型上拥有构造函数的全部属性和方法(包括构造函数的原型上的方法和属性),继承实现方法如下:

原型链继承

优点: 1.简单,子类实例既是子类的实例也是父类的实例

            2.父类在原型上新增的方法和属性都能被子类获取到

缺点: 1.传参不方便,只能再继承的时候传递参数,无法在创建子类实例的时候传入参数

            2.无法实现多继承(一个子类继承多个父类)

            3.原型上的属性、方法被所有的实例共享

2.构造继承

    创建子类函数,在函数内部直接调用构造函数,如果构造函数有参数在这里传参,继承实现方法如下:

构造继承

优点: 1.传参方便,可以在创建实例时传参

            2.可以实现多继承

缺点: 1.无法继承父类原型上的属性和方法 

            2.因为原型上没有方法,所以无法实现函数复用

3.组合继承

        同时使用构造继承和原型链继承。继承实现方法如下:

组合继承

优点: 1.综合了构造继承和原型链继承的优点,并且去除他们的缺点,总体而言是一个比较好的继承方案

缺点: 1.因为同时使用了原型链继承和构造继承,很明显可以看出父类实例的属性被调用了两次,浪费内存

4.原型式继承

        创建一个函数传入要继承的父对象,内部创建空的子类函数,然后在子类函数外部将父对象赋值给子类函数的原型,再返回子类函数的new执行结果。继承实现方法如下:

原型式继承

5.寄生继承

        函数内调用原型式继承,赋值给一个对象,然后可以自定义增加它的一些属性和方法。继承实现方法如下:

寄生继承

6.寄生组合继承(最完美继承方式)

        通过寄生方式,去掉父类的实例属性,在调用两次父类的构造的时候,就不会初始化两次实例方法或属性,避免的组合继承的缺点,也就是重新创建一个空的函数,将父类的原型拷贝给这个空函数,然后对子类函数执行这个空函数。继承实现方法如下:

寄生组合继承

优点:全身都是优点

缺点:实现复杂

相关文章

  • JS面向对象

    类与实例 创建类 实例化 类与继承 实现继承的几种方式 方式一:利用构造函数进行继承 但是这种方法缺点是无法继承父...

  • 多线程

    多线程 创建与启动 方式1:继承于Thread类 继承Thread类 重写run方法 创建对象 调用start方法...

  • 微信小程序中如何引用自定义的类

    1.先封装一个http类,在util/http.js中 创建classice.js 去继承HTTP类 在class...

  • JS类与继承

    一些概念 prototype是构造函数的指针,指向原型对象。讲述的是构造函数和原型对象之间的关系。__proto_...

  • JS继承与类

    继承 概念 通过【某种方式】让一个对象可以访问到另一个对象中的属性和方法,我们把这种方式称之为继承 并不是所谓的x...

  • 12. 面向对象(继承/接口/抽象)

    [TOC] 面向对象 继承与派生 继承 什么是继承?继承是一种创建新的类的方式 在python中,新建的类可以继承...

  • 12.面向对象(object-oriented)

    创建CityClass类 然后创建子类,继承CityClass类继承类的特点:可以被继承,但要标记为开放类(可见性...

  • 线程创建得方式

    线程的创建有1.继承thread类继承Thread类创建线程的步骤为: (1)创建一个类继承Thread类,重写r...

  • Java之面向对象详解

    1.Java面向对象的三个特征与含义 继承:继承是从已有类得到继承信息创建新类的过程。提供继承信息的类被称为父类(...

  • #js继承

    js继承的概念 js里常用的如下两种继承方式: 原型链继承(对象间的继承)类式继承(构造函数间的继承) 类式继承是...

网友评论

      本文标题:JS类的创建与继承

      本文链接:https://www.haomeiwen.com/subject/icsxwltx.html