首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS 继承的多种方法

一、原型链 学过java的同学应该都知道,继承是java的重要特点之一,许多面向对象的语言都支持两种继承方式:接口继承和实现继承,接口继承继承方法签名,而实现继承继承实际的方法,在js中,由于函数没有签名...,融合了它们的优点,现在已经成为js中最常用的继承方法。...寄生组合式继承 组合继承js中最经常用到的一种继承方法,而我们前面也已经说了组合继承的缺点,组合继承需要调用两次超类型构造函数,一次是在创建子类型原型的时候,另一次是在子类型构造函数内部,子类型最终会包含超类型对象的全部实例属性...7. es6中的继承 我们在前面创建对象中也提到了es6中可以使用Class来创建对象,而同样的道理,在es6中,也新增加了extends实现Class继承Class 可以通过extends关键字实现继承...class Point {} class ColorPoint extends Point {} 上面这个例子中可以实现ColorPoint类继承Point类,这种简洁的语法确实比我们上面介绍的那些方法要简洁的好多呀

2.8K10

JS 继承

index extends React.Component{ // ... } React github源码 面试官可以顺着这个问 JS继承的相关问题,比如: ES6 的 class 继承用...构造函数 ES6 extends 继承做了什么操作 我们先看看这段包含静态方法的 ES6 继承代码: // ES6 class Parent{ constructor(name){...推荐阅读JS继承相关的书籍章节 《JavaScript高级程序设计第3版》第6章——面向对象的程序设计 6种继承的方案,分别是原型链继承、借用构造函数继承、组合继承、原型式继承、寄生式继承、寄生组合式继承...上卷第6章——行为委托和附录A(ES6中的class) 总结 继承对于JS来说就是父类拥有的方法和属性、静态方法等,子类也要拥有。...回顾寄生组合式继承,主要就是三点: 子类构造函数的 proto指向父类构造器,继承父类的静态方法 子类构造函数的 prototype的 proto指向父类构造器的 prototype,继承父类的方法

2.8K32

红宝书 4:class 继承的重点

;原型链继承又存在引用值属性的修改不独立的问题;组合继承又存在两次调用构造函数的问题,寄生组合继承,写起来又太麻烦了,总之,在 class 出现前,JavaScipt 实现继承真是件麻烦事儿。...类可以包含: 构造函数方法 实例方法 获取函数 设置函数 静态类方法 这些项都是可选的 constructor class Person { constructor(name) {...我们不能在类的实例上调用静态方法,只能通过类本身调用。不做赘述。 继承 ECMAScript 6 新增特性中最出色的一个就是原生支持了类继承机制。虽然类继承使用的是新语法,但背后依旧使用的是原型链。...让我们再回顾构造函数继承和原型链继承 2 个经典的问题: ① 构造函数继承的问题:构造函数外在原型上定义方法,不能重用 function SuperType(){} SuperType.prototype.sayName...class 继承完美的解决了构造函数继承的问题,和原型链继承的问题,写起来也没有组合继承、寄生继承那么麻烦,如果非得用 JS 模拟面向对象编程,class 必不可少!!

18920

JS实现继承的几种方法总结

文章目录 一、基本代码 二、实现继承方法: 1.原型链继承 2.构造继承: 3.实例继承 4.拷贝继承: 5.组合继承: 6.寄生组合继承: 7.class – extends – – ES6 一...(call多个父类对象) 缺点: 实例并不是父类的实例,只是子类的实例 只能继承父类的实例属性和方法,不能继承原型属性/方法 无法实现函数复用,每个子类都有父类实例函数的副本,影响性能 ---- 3.实例继承.../方法,也可以继承原型属性/方法 既是子类的实例,也是父类的实例 不存在引用属性共享问题 函数可复用 可传参 缺点: 调用了俩次构造函数,生成了俩份实例(子类实例将子类原型上的那份屏蔽了) ---- 6....寄生组合继承: //核心:通过寄生方式,砍掉父类的实例属性,这样,在调用俩次父类的构造的时候,就不会初始化俩次实例方法/属性,避免了组合继承的缺点。...– extends – – ES6 语法糖,底层任然是原型链继承的方式 https://es6.ruanyifeng.com/#docs/class-extends 发布者:全栈程序员栈长,转载请注明出处

1.1K40

JS进阶:继承

在理解继承之前,需要知道 js 的三个东西: 什么是 JS 原型链 this 的值到底是什么 JS 的new 到底是干什么的 一、什么是 JS 原型链 我们知道 JS 有对象,比如 var obj =...缺点: 只能继承父类的实例属性和方法,不能继承原型属性/方法 无法实现复用,每个子类都有父类实例函数的副本,影响性能 3、组合继承 组合上述两种方法就是组合继承。...用原型链实现对原型属性和方法继承,用借用构造函数技术来实现实例属性的继承。...所以,组合模式的缺点就是在使用子类创建实例对象时,其原型中会存在两份相同的属性/方法。 4、原型式继承 利用一个空对象作为中介,将某个对象直接赋值给空对象构造函数的原型。...let p = new Rectangle(); // ReferenceError class Rectangle {} 2、ES5继承和ES6继承的区别 ES5的继承实质上是先创建子类的实例对象,

4.4K10

js实现继承

js实现继承 经典继承(原型链) 缺点:过多的继承了没用的属性 Grandfather.prototype.lastName = 'zhang' function Grandfather() {...father function Son() { this.hobby = 'game' } var son = new Son() console.log(son); ​ son只想要继承...grandfather的lastName属性,但是由于原型链的关系,造成了son既会继承grandfather自神的东西,grandfather的原型的东西,father自身的东西和father原型上的东西...,造成了不必要的继承 共享原型 本质:重写原型对象 优点:只会继承父的原型,不会继承父原本自带的属性或方法(只有调用new Father()才会继承自身的东西) 缺点:给本身的原型添加属性或方法时,会把继承的那个原型也修改了...) 雏形 本质:重写原型对象 优点:只会继承父的原型,不会继承父原本自带的属性或方法(只有调用new Father()才会继承自身的东西) 缺点:1,这样继承后即使修改了son的原型也不会修改father

5.3K20

class继承之super的使用

我们大家都知道,在class继承中,子类如果想要继承父类且能生成子类实例,就必须要在constructor中调用super(),那么super在此处到底代表什么呢?...2. super作为对象 super作为对象用在子类中,我们仍然需要加以区分super是用在子类的普通方法还是静态方法中。...,会与在静态方法中的使用形成对比 =====》对于第一点,如下: class C{ constructor() { } } C.cc=7; C.prototype.cc=100; class...super指向父类(不是父类的原型对象) 在子类的静态方法中通过super调用父类方法时,super内部的this指向子类(不是子类的实例) =====》对于第一点,如下: class E{...最后总总结一下~ super作为函数使用,代表父类的构造函数,只能用在子类的构造函数中; super作为对象使用,在普通方法之中指向父类的原型对象,在静态方法之中指向父类;在普通方法中调用父类方法,super

54720

ES6之class继承

class语法为我们提供了构造函数的语法糖,响应的,也给我们提供了ES5通过原型链实现继承提供了extends关键字实现继承继承这个概念对面后台应该也是非常常见。...通过extends继承,语法: class User{} class Son extends User{} 继承之后Son可以使用User类的所有属性和方法class User{ constructor...这是因为子类实例的构建,基于父类实例,只有super方法才能调用父类实例。静态方法也会继承。...静态方法中,super指向父类,也就是User类: class User{ constructor(){ this.a = 10; } static eat(val...类也是有prototype和__proto__属性的,相应的构成原型链: 子类的__proto__属性是构造函数的继承,指向父类 子类的prototype属性的__proto__属性,表示方法继承,指向父类的

48310

ES6 class的类继承

继承的概念类继承是一种通过创建子类来继承父类的属性和方法的方式。通过类继承,子类可以获得父类的实例属性和方法,并且可以通过子类的原型链访问父类的静态属性和方法。...然后,我们定义了一个Dog类,它通过extends关键字继承了Animal类,并添加了一个新的方法bark()。通过类继承,Dog类获得了Animal类的属性和方法。...我们创建了一个Dog类的实例,并调用了继承的eat()方法和自身的bark()方法。...示例2:多继承class Parent1 { method1() { console.log('This is Parent 1 method.'); }}class Parent2 { method2...我们创建了一个Child类的实例,并分别调用了继承方法method1()、method2()和自身的方法method3()。

34140

JS原型继承和类式继承

类式继承(构造函数) JS中其实是没有类的概念的,所谓的类也是模拟出来的。特别是当我们是用new 关键字的时候,就使得“类”的概念就越像其他语言中的类了。...我们说的原型继承,就是将父对像的方法给子类的原型。子类的构造函数中不拥有这些方法和属性。...其次类式继承是不可变的。在运行时,无法修改或者添加新的方法,这种方式是一种固步自封的死方法。而原型继承是可以通过改变原型链接而对子类进行修改的。...用类式继承属性,而原型继承方法。这种模式避免了属性的公用,因为一般来说,每一个子类的属性都是私有的,而方法得到了统一。这种模式称为组合模式,也是继承类式常用到的一种方法。...从这里,我们也可以看到类继承和原型基础的一些区别。 结论 原型继承比较符合js这种语言的特点。因为它本身就是js强大的原型的一部分。

3.4K90
领券