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

js实现继承几种方式

js作为一个面向对象弱类型语言,继承也是其非常强大特性之一。一般情况下会出现下面的6中继承方式。...无法实现多继承 来自原型对象引用属性是所有实例共享 创建子类实例时,无法向父类构造函数传参 2、构造继承 核心:使用父类构造函数来增强子类实例,等于是复制父类实例属性给子类(没用到原型) function...console.log(cat.eat("猫粮"));//此处会报错,通过构造继承方式无法继承原型属性和方法 console.log(cat instanceof Animal); // false...) 缺点: 实例并不是父类实例,只是子类实例 只能继承父类实例属性和方法,不能继承原型属性/方法 无法实现函数复用,每个子类都有父类实例函数副本,影响性能 3、实例继承 核心:为父类实例添加新特性...) 6、寄生组合继承(推荐) 核心:通过寄生方式,砍掉父类实例属性,这样,在调用两次父类构造时候,就不会初始化两次实例方法/属性,避免组合继承缺点 function Cat(name){

1.4K20

JavaScript几种继承方式

JavaScript几种继承方式 原型链继承 借助构造函数继承(经典继承) 组合继承:原型链 + 借用构造函数(最常用) 原型式继承 (Object.create) 寄生式继承 寄生组合式继承(最理想...寄生式继承 创建一个用于封装继承过程函数,该函数在内部以某种方式来增强对象 function createObj (original) { // 通过调用函数创新一个新对象 var clone...参考 JavaScript常见六种继承方式[1] JS继承几种方式[2] JavaScript深入之继承多种方式和优缺点[3] ECMAScript6入门之 Class继承[4] 参考资料 [1...] JavaScript常见六种继承方式: https://segmentfault.com/a/1190000016708006 [2] JS继承几种方式: https://juejin.im/post.../5b654e88f265da0f4a4e914c [3] JavaScript深入之继承多种方式和优缺点: https://github.com/mqyqingfeng/Blog/issues/16

46820
您找到你想要的搜索结果了吗?
是的
没有找到

JS实现继承方式

JS实现继承方式 构造函数继承 原型继承 组合(构造函数+原型)继承 Class继承 ---- 构造函数继承 构造函数继承关键:在Child构造函数中执行Parent.call(this)...Child继承 function Child(name, type){ Parent.call(this, name); this.type = type; } 原型继承 原型继承关键:...组合继承 组合继承关键: 1.属性使用构造函数继承 - 避免了原型继承中Parent引用属性被所有Child实例共享缺陷。...2.方法使用过原型继承 - 避免了构造函数继承中方法重复拷贝、浪费内存缺陷 function Parent(){ this.name = name; this.hobby = [];...因为子类没有自己this对象,而是继承父类this对象。如果不调用super函数,子类就得不到this对象。super()作为父类构造函数,只能出现在子类constructor()中。

2K20

JS 原生方法原理探究(四):如何实现继承几种方式

这是JS 原生方法原理探究系列第四篇文章。本文会介绍如何实现 JS 中常见几种继承方式,同时简要它们优缺点。 实现继承方法 ?...此外,对于父类原型上方法,子类是无法继承,因为这种继承方式并没有使用到原型。 3)组合继承 看起来,原型链继承擅长方法继承,而借用构造函数继承擅长属性继承,那么能不能取二者之长呢?...,使用构造函数继承方式继承属性。...4) 原型式继承 原型式继承所做事情类似于浅拷贝一个对象,再通过自定义方式增强新对象。它能够方便地实现在不同对象之间共享信息,同时又不需要额外创建构造函数(内部做了处理)。...inherit(SuperType,SubType) const obj = new SubType() 注意几个要点: 属性继承仍然是采用借用构造函数继承方式,关键是方法继承

1.4K20

Js继承实现方式

Js继承实现方式 继承是面向对象软件技术当中一个概念,与多态、封装共为面向对象三个基本特征。继承可以使得子类具有父类属性和方法或者重新定义、追加属性和方法等。...不足 实例并不是父类实例,只是子类实例 只继承了父类构造函数属性和方法,没有继承父类原型属性和方法 每个子类都有父类实例函数副本,拷贝了父类函数而不是引用,影响性能 实例继承 为父类实例增加成员与方法...Child("child"); // 实例化子类 child.say(); // child console.log(child.from); // child 特点 实例化子类时可以向父类构造函数传参 子类实例化方式可以为...父类新增原型方法与属性,子类都能访问到 不足 不能继承父构造函数实例对象成员 所有子类实例都会共享父类原型对象中属性 组合继承 组合原型链继承和借用构造函数继承,结合了两种模式优点,传参和复用...寄生组合继承 通过寄生方式,砍掉父类实例属性,在调用两次父类构造时候,就不会初始化两次实例方法和属性,避免组合继承缺点 // 定义父类 function Parent(from){

2K20

javascript 面向对象(实现继承几种方式)

1、原型链继承 核心: 将父类实例作为子类原型 缺点: 父类新增原型方法/原型属性,子类都能访问到,父类一变其它都变了 function Person (name) {...(继承到了当前对象原型中)   console.log(result.getAge()); //22   //调用了从Parent原型中扩展来方法 2、构造继承 基本思想 借用构造函数基本思想就是利用...核心:使用父类构造函数来增强子类实例,等于是复制父类实例属性给子类(没用到原型) 缺点: 方法都在构造函数中定义, 只能继承父类实例属性和方法,不能继承原型属性/方法,无法实现函数复用,每个子类都有父类实例函数副本...3、组合继承 组合继承(所有的实例都能拥有自己属性,并且可以使用相同方法,组合继承避免了原型链和借用构造函数缺陷,结合了两个优点,是最常用继承方式) 核心:通过调用父类构造,继承父类属性并保留传参优点...'小红'] 4、寄生组合继承 核心:通过寄生方式,砍掉父类实例属性,这样,在调用两次父类构造时候,就不会初始化两次实例方法/属性,避免组合继承缺点 缺点:堪称完美,但实现较为复杂

66080

js各种继承方式汇总

js各种继承实现汇总 首先定义一个父类: function Animal(name) { this.name = name || '动物' this.sleep = function ()...方式) 特点: 1、子类构造中进行父类构造调用 优点: 1、实现了多继承,想继承哪个直接在子类构造里面call或者apply哪个就行 2、避免所有子类实例共享父类引用属性问题 3、创建子类实例时...,可以向父类传递参数 缺点: 1、没用到原型,只是单纯继承了父类实例属性及方法 2、没继承原型上属性及方法 3、每个子类都有父类方法属性副本,影响性能,没有实现父类函数复用 function...) // false,等于是复制父类实例属性给子类,没用到原型 实例继承 特点: 1、子类构造中返回父类实例 优点: 1、可以继承原型上属性或方法 缺点: 1、实例为父类实例,而非子类实例...(暴力继承) 特点: 1、子类构造中强制拷贝父类原型上属性或方法 优点: 1、可以多重继承 缺点: 1、效率较低,内存占用高 2、不能继承父类不可枚举属性(不能用for in遍历

2.2K70

JS实现继承几种方法总结

文章目录 一、基本代码 二、实现继承方法: 1.原型链继承 2.构造继承: 3.实例继承 4.拷贝继承: 5.组合继承: 6.寄生组合继承: 7.class – extends – – ES6 一...(call多个父类对象) 缺点: 实例并不是父类实例,只是子类实例 只能继承父类实例属性和方法,不能继承原型属性/方法 无法实现函数复用,每个子类都有父类实例函数副本,影响性能 ---- 3.实例继承...效率极低,内存占用高(因为要拷贝父类属性) 无法获取父类不可枚举方法(for in不能访问到) ---- 5.组合继承: //核心:通过调用父类构造,继承父类属性并保留传参优点,然后通过将父类实例作为子类原型...) ---- 6.寄生组合继承: //核心:通过寄生方式,砍掉父类实例属性,这样,在调用俩次父类构造时候,就不会初始化俩次实例方法/属性,避免了组合继承缺点。...Cat.prototype.constructor = Cat; //修复构造函数 特点: 基本上是完美的 缺点: 实现起来较为复杂 ---- 7.class – extends – – ES6 语法糖,底层任然是原型链继承方式

1.2K40

JS获取html对象几种方式说明

大家好,又见面了,我是全栈君 document.getElementById(“zx”); 通过ID获取html元素对象,ID号在html文档当中应该是唯一。返回是唯一element对象。...document.getElementsByTagName(“span”)[0]; 通过标签查找html对象,由于html标签在一个页面中可能重复很多次,所以当前页面返回是一个数组。...可以根据标签出现位置定位元素对象。所有浏览器都兼容。...所以这个方法返回也是一个数组,同样我们也可以根据html当中name位置,进行对name定位。IE系列不兼容,不推荐使用。...innerHTML:这个方法是获取该html元素具体html代码 document.getElementById(“zx”).innerHTML; 还可以更新元素html代码: document.getElementById

4.7K20

JS 匿名函数——几种不同调用方式

func=function(){ } 调用:func(); var show = function(){ alert('hello'); }; show(); 注意:使用匿名函数表达式时,函数调用语句...原因:检查装载时,会先对show变量及这个匿名函数声明,此时,还未将匿名函数赋值给show变量,如果在表达式之前调用,会报错 show is not a function js代码执行顺序问题 js...检查装载阶段:会先检测代码语法错误,进行变量、函数声明 执行阶段:变量赋值、函数调用等,都属于执行阶段。 3.自执行函数。这里我总结了8种常用匿名函数调用方法: //1.使用 !...function(){ document.write('ni hao'); }() //2.无法表明函数与之后()整体性,不推荐使用。...如发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

3.9K10
领券