首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js继承用的多吗

在JavaScript中,继承的使用是比较常见的,尤其是在构建大型应用和复用代码时。JavaScript的继承主要通过原型链(Prototype Chain)和ES6引入的类(Class)语法来实现。

基础概念

原型链继承:在JavaScript中,每个对象都有一个原型(prototype),当试图访问一个对象的属性时,如果该对象本身没有这个属性,就会去它的原型上找,这个过程会一直持续到找到该属性或者到达原型链的末端(null)。

类继承:ES6引入了类的概念,使得JavaScript的继承更加直观和易于理解。类继承通过extends关键字实现,子类可以继承父类的属性和方法。

优势

  • 代码复用:通过继承,子类可以复用父类的代码,减少重复。
  • 层次结构:继承可以构建出清晰的类层次结构,便于管理和扩展。
  • 多态性:继承允许子类覆盖父类的方法,实现多态性。

类型

  • 原型链继承:通过原型链实现,简单但存在一些问题,如所有子类实例共享父类的引用类型属性。
  • 构造函数继承:通过在子类构造函数中调用父类构造函数实现,避免了引用类型属性共享的问题,但无法复用父类原型上的方法。
  • 组合继承:结合了原型链继承和构造函数继承的优点,但存在调用两次父类构造函数的问题。
  • 原型式继承:通过Object.create()方法实现,适用于不需要构造函数的场景。
  • 寄生式继承:在原型式继承的基础上,对创建的对象进行增强。
  • ES6类继承:通过classextends关键字实现,语法简洁,易于理解。

应用场景

  • 框架开发:在开发框架时,如React、Vue等,继承被广泛用于构建组件系统。
  • 游戏开发:在游戏开发中,继承用于创建不同类型的角色、道具等。
  • 企业级应用:在企业级应用中,继承用于构建复杂的业务逻辑和数据模型。

遇到的问题及解决方法

问题1:原型链继承中,所有子类实例共享父类的引用类型属性。

代码语言:txt
复制
function Parent() {
  this.arr = [1, 2, 3];
}

function Child() {}

Child.prototype = new Parent();

const child1 = new Child();
const child2 = new Child();

child1.arr.push(4);

console.log(child1.arr); // [1, 2, 3, 4]
console.log(child2.arr); // [1, 2, 3, 4],所有子类实例共享父类的引用类型属性

解决方法:使用组合继承或ES6类继承。

代码语言:txt
复制
class Parent {
  constructor() {
    this.arr = [1, 2, 3];
  }
}

class Child extends Parent {
  constructor() {
    super();
  }
}

const child1 = new Child();
const child2 = new Child();

child1.arr.push(4);

console.log(child1.arr); // [1, 2, 3, 4]
console.log(child2.arr); // [1, 2, 3],每个子类实例拥有独立的引用类型属性

问题2:构造函数继承中,无法复用父类原型上的方法。

代码语言:txt
复制
function Parent() {
  this.sayHello = function() {
    console.log('Hello');
  };
}

function Child() {
  Parent.call(this);
}

const child = new Child();
console.log(child.hasOwnProperty('sayHello')); // true,但无法复用父类原型上的方法

解决方法:使用组合继承或ES6类继承。

代码语言:txt
复制
class Parent {
  constructor() {
    this.sayHello = function() {
      console.log('Hello');
    };
  }

  sayHi() {
    console.log('Hi');
  }
}

class Child extends Parent {
  constructor() {
    super();
  }
}

const child = new Child();
console.log(child.hasOwnProperty('sayHello')); // true
child.sayHi(); // Hi,可以复用父类原型上的方法

通过以上方法和示例代码,可以有效地解决JavaScript继承中常见的问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【JAVA冷知识】JAVA真的不支持多继承吗?让我们用内部类去实现JAVA的多继承吧

写在前面 ---- JAVA冷知识,今天和小伙伴分享的是 通过内部类的方式实现JAVA的多继承 一个Demo和JDK源码中的具体场景 部分内容参考 《编写高质量代码(改善Java程序的151个建议)》...——烽火戏诸侯 《剑来》 ---- 众多周知,对于面向对象语言来讲,JAVA是不支持多继承的,只支持单继承,但是提供了接口来补偿。...如果实现java的多继承,其实很简单,关键是对于内部类的特征的掌握,内部类可以继承一个与外部类无关的类,保证了内部类天然独立性,根据这个特性从而实现一个类可以继承多个类的效果 下面我们看一个Demo,...这种方式实现的多继承,完全可以通组合的方式来实现,我们简单分析一下优缺点 优缺点分析 优点: 通过内部类的方式,把继承关系控制在类的内部,理论上比通过组合的方式更加安全,代码可读性要好一点。...有点类似,这里的List通过subList生成子list方式也是通过内部类继承方式的多继承实现的。

65020

day018: JS如何实现继承?继承一定是好的设计吗?​

第六篇: JS如何实现继承?继承一定是好的设计吗?...之前的问题都得以解决。但是这里又徒增了一个新问题,那就是Parent3的构造函数会多执行了一次(Child3.prototype = new Parent3();)。这是我们不愿看到的。...追问: 面向对象的设计一定是好的设计吗? 不一定。从继承的角度说,这一设计是存在巨大隐患的。...也就是说加油这个方法,我现在是不需要的,但是由于继承的原因,也给到子类了。 继承的最大问题在于:无法决定继承哪些属性,所有属性都得继承。...那如何来解决继承的诸多问题呢? 用组合,这也是当今编程语法发展的趋势,比如golang完全采用的是面向组合的设计方式。

64210
  • Python中类的继承、多层继承和多继承

    Python中,一个类可以通过继承的方式来获得父类中的非私有属性和非私有方法。...一、继承、重写、和调用重写的父类方法 继承的语法为在类名后的小括号()中写入要继承的父类名,如果要继承多个类则中间用逗号分隔。...4.如果在子类重写父类的方法中,需要使用父类同名方法中的功能,在父类功能基础上做扩展,则子类可以在重写的方法中调用父类被重写的方法,使用super()来调用。 ? 二、类的多层继承 类可以多层继承。...继续上面的类,我们定义的类Mi继承自Phone类,Phone类继承自Electrical类,这样就构成了多层继承。...三、类的多继承 class Computer(Electrical): def coding(self): print('Coding something!')

    5.5K30

    C++继承中的多继承语法与菱形继承

    多继承语法 C++允许一个类继承多个类 语法: class 子类 :继承方式 父类1 , 继承方式 父类2......多继承可能会引发父类中有同名成员出现,需要加作用域区分 C++实际开发中不建议用多继承 示例: class Base1 { public: Base1() { m_A = 100; } public...} public: int m_C; int m_D; }; //多继承容易产生成员同名的情况 //通过使用类名作用域可以区分调用哪一个基类的成员 void test01() { Son...羊继承了动物的数据,驼同样继承了动物的数据,当草泥马使用数据时,就会产生二义性。...使用了虚继承后对比未使用虚继承解决菱形继承 总结: 菱形继承带来的主要问题是子类继承两份相同的数据,导致资源浪费以及毫无意义 利用虚继承可以解决菱形继承问题

    73010

    python之类的单继承与多继承

    Python 优雅的语法和动态类型以及解释型语言的本质,使它成为多数平台上写脚本和快速开发应用的理想语言。下面我们来介绍一下python的类的单继承与多继承。...---- 二、单继承与多继承 1、单继承   在程序中,继承描述的是事物之间的从属关系。在继承关系中,已有的、设计好的类称为父类或基类,新设计的类称为子类或派生类。...继承可以分为单继承和多继承两大类。   在Python中,当一个子类只有一个父类时称为单继承。...2、多继承   多继承指一个子类可以有多个父类,它继承了多个父类的特性。多继承可以看作是对单继承的扩展,其语法格式如下: class 子类名(父类名,父类名…):   例:多继承示例。...注意:在Python中,如果两个父类中有同名的方法,调用该同名方法时会调用先继承类中的方法。   例如:如果Sofa和Bed类中有同名的方法,用”语句定义子类时,子类会先继承Sofa类。

    49450

    js 继承的是什么?如何实现继承?

    继承的含义: 继承是面向对象编程中的一个重要概念,通过继承可以使子类的实例使用在父类中定义的属性和方法。...二、 构造函数继承 针对前面原型链继承可能会存在公用一个原型链的问题,那么我们可以给大家介绍一种方式:构造函数的继承。构造函数的继承相当于将父类复制给子类。...三、 组合继承 原型链继承能继承父类原型链上的属性,但是可能会存在篡改的问题;而构造函数继承不会存在篡改的问题,但是不能继承原型上面的属性。那么我们是否可以将两者进行结合呢?...六、 寄生组合式继承 前面说了这么多,每种继承方式都有自己的优点和缺点,那么是不是可以将这些继承的方式做一个合并:以他之长补己之短呢?...其实我们知道,class语法也是由es5语法来写的,其继承的方法和寄生组合式继承的方法一样。关于es6的类,我在代码自检的时候遇到的两个重点,值得注意下的是: 函数声明会提升,类声明不会。

    1.8K40

    JS实现继承的方式

    JS实现继承的方式 构造函数继承 原型继承 组合(构造函数+原型)继承 Class继承 ---- 构造函数继承 构造函数继承的关键:在Child构造函数中执行Parent.call(this)...Child继承 function Child(name, type){ Parent.call(this, name); this.type = type; } 原型继承 原型继承的关键:...组合继承 组合继承的关键: 1.属性使用构造函数继承 - 避免了原型继承中Parent引用属性被所有Child实例共享的缺陷。...Class继承 class继承用extends实现继承 class Person{ constructor(skin,language){ this.skin = skin; this.language...因为子类没有自己的this对象,而是继承父类的this对象。如果不调用super函数,子类就得不到this对象。super()作为父类的构造函数,只能出现在子类的constructor()中。

    2.1K20

    Js继承的实现方式

    Js继承的实现方式 继承是面向对象软件技术当中的一个概念,与多态、封装共为面向对象的三个基本特征。继承可以使得子类具有父类的属性和方法或者重新定义、追加属性和方法等。...、父类原型属性和方法 不足 无法实现多继承 子类实例化时无法向父类的构造函数传参 所有子类实例都会共享父类的原型对象中的属性 构造函数继承 当子类构造函数被调用时,借助call或者apply调用父类构造方法实现对于...child.say(); // child console.log(child.from); // child 特点 子类实例不会共享父类属性方法 实例化子类时可以向父类构造函数传参 通过调用多个父类构造函数可以实现多继承...new Child()或直接调用Child() 不足 不支持多继承 实例是父类的实例,不是子类的实例 同样也是将父类的成员与方法做了实例化拷贝 拷贝继承 通过直接将父类的属性拷贝到子类的原型中实现继承...var child = new Child("child"); // 实例化子类 child.say(); // child console.log(child.from); // child 特点 支持多继承

    2K20

    python中类的多继承

    ---- 本节知识视频教程 一、多继承 类似于c++中某个类,一次可以继承多个父类,所有被继承的这些父类的方法和属性都将可以被子类使用。...注意:如果所继承的父类的方法相同的情况下,那么按照从左到右的方向,依次由写在左边的类的方法覆盖右边类的方法。...如果某个类的方法与继承的父级中有相同的方法名称,那么我们的结果就是以这个子类的方法名称作为最终的 方法。 二、查看父类和属性继承规则 1.如何查看继承的多个父级类是哪些?...可以通过子类的__bases__ (注意这里有两个下划线) 2.Python中属性的继承规则呢? 通过测试,我们知道属性的继承规则和方法的继承规则是一样的。...三、总结强调 1.掌握多继承类的定义 2.掌握查看多继承类的魔法属性 3.掌握多继承类的调用规则 4.掌握属性的继承规则 相关文章: python应用场景有哪些?岗位工资如何?

    1.4K30

    面试官:垃圾回收算法用的多吗?

    程序计数器 一块较小的内存空间, 是当前线程所执行的字节码的行号指示器,当前线程所执行的行号指示器(当前指令的地址)。...”(Reference Chain),如果某个对象到GC Roots间没有任何引用链相连,或者用图论的话来说就是从GC Roots到这个对象不可达时,则证明此对象是不可能再被使用的(可回收的)。...而当需要支持并发标记时,即标记期间应用线程还在继续跑,对象间的引用可能发生变化,多标和漏标的情况就有可能发生。...多标-浮动垃圾 假设已经遍历到E(变为灰色了),此时应用执行了 objD.fieldE = null : 此刻之后,对象E/F/G是“应该”被回收的。...static代码块一定是线程安全的吗?

    41830

    js实现继承的几种方式

    js作为一个面向对象的弱类型语言,继承也是其非常强大的特性之一。一般情况下会出现下面的6中继承方式。...无法实现多继承 来自原型对象的引用属性是所有实例共享的 创建子类实例时,无法向父类构造函数传参 2、构造继承 核心:使用父类的构造函数来增强子类实例,等于是复制父类的实例属性给子类(没用到原型) function...console.log(cat instanceof Cat); // true 特点: 解决了原型继承中,子类实例共享父类引用属性的问题 创建子类实例时,可以向父类传递参数 可以实现多继承(call多个父类对象...缺点: 实例是父类的实例,不是子类的实例 不支持多继承 4、拷贝继承 function Cat(name){ var animal = new Animal(); for(var p in animal...猫正在吃:猫粮 console.log(cat instanceof Animal); // false console.log(cat instanceof Cat); // true 特点: 支持多继承

    1.4K20

    js的继承与原型链

    对于使用基于类的语言,如 Java 的开发人员,js 令人困惑,因为它是动态的,并且本身不提供一个 class 实现。...谈到继承时,js 只有一种结构:对象。 每个实例对象( object )都有一个私有属性(称之为 __proto__ )指向它的构造函数的原型对象(prototype )。...该原型对象也有一个自己的原型对象( proto ) ,层层向上直到一个对象的原型对象为 null。根据定义,null 没有原型,并作为这个原型链中的最后一个环节。...几乎所有 js 中的对象都是位于原型链顶端的 Object 的实例。 尽管这种原型继承通常被认为是 JavaScript 的弱点之一,但是原型继承模型本身实际上比经典模型更强大。...例如,在原型模型的基础上构建经典模型相当简单。

    1.4K10

    JS 继承的多种方法

    一、原型链 学过java的同学应该都知道,继承是java的重要特点之一,许多面向对象的语言都支持两种继承方式:接口继承和实现继承,接口继承只继承方法签名,而实现继承则继承实际的方法,在js中,由于函数没有签名...SuperType,接着创建出SubType的实例instance,因此,instance可以访问SubType和SuperType原型上的属性和方法,也就是实现了继承,继承关系我们可以用下面的图说明。...,融合了它们的优点,现在已经成为js中最常用的继承方法。...寄生组合式继承 组合继承是js中最经常用到的一种继承方法,而我们前面也已经说了组合继承的缺点,组合继承需要调用两次超类型构造函数,一次是在创建子类型原型的时候,另一次是在子类型构造函数内部,子类型最终会包含超类型对象的全部实例属性...,第二步为创建的副本添加constructor属性,从而弥补因重写原型而失去的默认的constructor属性,最后一步将副本也就是新对象赋值给子类型的原型,因此,我们可以用这个函数去替换前面说到为子类型原型赋值的语句

    2.8K10

    typescript 多继承_说明类的继承和多态有什么作用

    前言 对于传统的 JavaScript 程序我们会使用函数和基于原型的继承来创建可重用的组件,但对于熟悉使用面向对象方式的程序员使用这些语法就有些棘手,因为他们用的是基于类的继承并且对象是由类构建出来的...最后通过person对象调用其sayHi方法 继承 在 TypeScript 里,我们可以使用常用的面向对象模式。 基于类的程序设计中一种最基本的模式是允许使用继承来扩展现有的类。...Snake类和 Horse 类都创建了 run 方法,它们重写了从 Animal 继承来的 run 方法,使得 run 方法根据不同的类而具有不同的功能。...公共,私有与受保护的修饰符 默认为public 在上面的例子里,我们可以自由的访问程序里定义的成员。...我们可以用下面的方式来重写上面的 Animal类: class Animal { public name: string; public constructor(theName: string

    1.2K20

    【C++】继承 ① ( 面向对象特点 | 类之间的关系 | 单继承与多继承 | 继承关系特性 )

    一、面向对象相关概念 1、面向对象特点 面向对象的 4 大特点 : 抽象 : 只关注对象的功能和行为 , 而不过问实现的具体细节 ; 封装 : 将对象的 属性 和 方法 封装在一起 ; 继承 : 新类中继承现有类的...作为参数 ; IS-A 类关系 : 类的继承 , 接口实现 ; 泛化关系 Generalization : 一般描述 和 具体描述 之间的关系 , 继承中的 父类 和 子类 就是这种关系 ;...; 子类 又称为 派生类 ; 2、单继承与多继承 单继承 与 多继承 : A 类 只有一个 子类 B 类 , 那么 该继承 就是 单继承 ; A 类 有多个子类 B1 类 , B2 类 … , 该 继承...是 多继承 ; 单继承 单继承是指一个类只能继承一个父类的特性和行为 ; 下面的代码中 , Child 类继承了 Parent 类的所有公有和保护成员 , 并且可以访问它们 ; 注意 : Child...}; 多继承 多继承是指一个类可以继承多个父类的特性和行为 ; 下面的代码中 , Child 类继承了 Parent1 和 Parent2 类的所有 公有 和 保护 成员 , 并且可以访问它们 ;

    22130

    Java8:接口里面可以写实现方法吗【可以】 、接口可以多继承吗【可以】

    比如下面这道题: 问: 接口里面可以写方法吗? 答: 当然可以啊,默认就是抽象方法。 . 问: 那接口里面可以写实现方法吗? 答:不可以,所有方法必须是抽象的。 . 问: 你确定吗?...问: 接口里面是可以写实现方法的,Java 8 开始就可以了,你用过 Java 8 吗?...通过这些交流,能看出,虽然开发版本用的是 Java 8,但实际用的还是 Java 8 之前的最基础的语法。...接口静态方法只可以直接通过静态方法所在的 接口名.静态方法名 来调用。 ▌接口默认方法多继承冲突问题 因为接口默认方法可以被继承并重写,如果继承的多个接口都存在相同的默认方法,那就存在冲突问题。...People 和 Man,此时在 IDEA 编辑器中就会报错: 这就是接口多继承带来的冲突问题,Boy 不知道该继承谁的,这显然也是个问题,IDEA 也会提示,需要重写这个方法才能解决问题: interface

    1.5K10

    【C++】多态 ⑫ ( 多继承 “ 弊端 “ | 多继承被禁用的场景 | 菱形继承结构的二义性 | 使用虚继承解决菱形继承结构的二义性 )

    一、多继承 " 弊端 " 1、多继承被禁用的场景 禁止使用多继承的场景 : 在 C++ 语言 环境 中 , 多继承 若干完整的 有成员函数 和 成员变量 的 类 , 是不推荐的做法 , 实际开发中 ,...绝对禁止 使用 上述类型的 多继承 ; 2、多继承弊端 多继承会带来一系列的问题 , 诸如 : 钻石问题 - 菱形继承结构 / 二义性错误 : 当一个类继承自多个类时 , 如果这些类有共同的基类 , 那么会出现菱形继承结构..., 这可能会降低代码的可维护性和可重用性 ; 复杂的构造和析构过程 : 多继承 的 子类 的 构造和析构过程 可能会变得非常复杂 , 当一个子类对象被创建时 , 需要调用所有基类的构造函数 ; 当一个对象被销毁时...; 在 菱形继承结构 中 , 虚继承可以使 重复继承 的 父类 , 只继承 依次 ; 多继承的二义性 参考 【C++】继承 ⑫ ( 继承的二义性 | virtual 虚继承 ) 博客 ; 二、代码示例...- 多继承弊端 1、错误示例 - 菱形继承结构的二义性 在下面的 菱形继承结构 中 , D 继承 B 和 C 类 , 但是 B 和 C 有共同的 父类 A , 假如 访问 D 对象 中 继承自 A 类的成员

    42720
    领券