广告
返回顶部
首页 > 资讯 > 前端开发 > 其他 >JavaScript如何实现继承的
  • 823
分享到

JavaScript如何实现继承的

2023-05-14 22:05:27 823人浏览 薄情痞子
摘要

javascript是一种面向对象的语言,而继承是面向对象编程的一个重要特性。在JavaScript中,继承的实现方式有多种,本文将介绍其中较为常见的几种方法。一、原型链继承原型链继承是JavaScript中最基本的一种继承方式,也是最常用

javascript是一种面向对象的语言,而继承是面向对象编程的一个重要特性。在JavaScript中,继承的实现方式有多种,本文将介绍其中较为常见的几种方法。

一、原型链继承

原型链继承是JavaScript中最基本的一种继承方式,也是最常用的一种。通过原型链继承,可以实现子类继承父类的属性和方法。

原型链继承的实现方法如下:

function Parent(name) {
    this.name = name;
    this.colors = ['red', 'green', 'blue'];
}

Parent.prototype.sayName = function() {
    console.log(this.name);
};

function Child(name, age) {
    this.age = age;
    Parent.call(this, name);
}

Child.prototype = new Parent();
Child.prototype.constructor = Child;

var child1 = new Child('Tom', 18);
child1.colors.push('black');
console.log(child1.colors);  // ['red', 'green', 'blue', 'black']
child1.sayName();  // Tom

var child2 = new Child('Jerry', 20);    
console.log(child2.colors);  // ['red', 'green', 'blue']
child2.sayName();  // Jerry

上述代码中,我们首先定义了一个父类Parent和一个子类Child。在Child中,我们使用Parent.call(this, name)调用了父类构造函数,并通过Child.prototype = new Parent()将Child的原型指向了Parent,从而实现了继承。在最后,我们创建了两个子类实例child1和child2,并验证了继承的效果。

原型链继承的优点是实现简单,容易理解。但它的缺点也很明显,即会造成原型对象中的引用类型属性被所有实例共享。

二、构造函数继承

构造函数继承是一种比较容易理解的继承方式,它通过在子类构造函数中调用父类构造函数实现继承。

构造函数继承的实现方法如下:

function Parent(name) {
    this.name = name;
    this.colors = ['red', 'green', 'blue'];
}

Parent.prototype.sayName = function() {
    console.log(this.name);
};

function Child(name, age) {
    Parent.call(this, name);
    this.age = age;
}

var child1 = new Child('Tom', 18);
child1.colors.push('black');
console.log(child1.colors);  // ['red', 'green', 'blue', 'black']
child1.sayName();  // TypeError: child1.sayName is not a function 

var child2 = new Child('Jerry', 20);    
console.log(child2.colors);  // ['red', 'green', 'blue']
child2.sayName();  // TypeError: child2.sayName is not a function

上述代码中,我们在子类构造函数Child中使用Parent.call(this, name)调用了父类构造函数,并将this指向子类实例,从而实现了继承。但由于构造函数继承并不会将父类原型中的方法继承下来,因此我们在子类中无法直接调用父类原型中的方法。

构造函数继承的优点是避免了原型链继承中引用类型属性被所有实例共享的问题,但它的缺点也很明显,即无法继承父类原型中的方法。

三、组合继承

组合继承是JavaScript中最常用的一种继承方式,它是将原型链继承和构造函数继承结合起来的一种方式,解决了两者各自的缺点。

组合继承的实现方法如下:

function Parent(name) {
    this.name = name;
    this.colors = ['red', 'green', 'blue'];
}

Parent.prototype.sayName = function() {
    console.log(this.name);
};

function Child(name, age) {
    Parent.call(this, name);
    this.age = age;
}

Child.prototype = new Parent();
Child.prototype.constructor = Child;

var child1 = new Child('Tom', 18);
child1.colors.push('black');
console.log(child1.colors);  // ['red', 'green', 'blue', 'black']
child1.sayName();  // Tom

var child2 = new Child('Jerry', 20);    
console.log(child2.colors);  // ['red', 'green', 'blue']
child2.sayName();  // Jerry

上述代码中,我们在子类构造函数Child中使用Parent.call(this, name)调用了父类构造函数,并将this指向子类实例,从而实现了继承。同时,我们在子类原型中通过Child.prototype = new Parent()使子类继承了父类的原型,从而继承了父类原型中的方法。

组合继承的优点是继承方式完整,既可以继承父类原型中的方法,又可以避免原型链继承中引用类型属性被所有实例共享的问题。但它的缺点是会调用两次父类构造函数,浪费了一定的内存空间。

四、寄生组合继承

寄生组合继承是组合继承的一种优化方式,它避免了在子类原型中多次调用父类构造函数的问题,从而减少了内存开销。

寄生组合继承的实现方法如下:

function Parent(name) {
    this.name = name;
    this.colors = ['red', 'green', 'blue'];
}

Parent.prototype.sayName = function() {
    console.log(this.name);
};

function Child(name, age) {
    Parent.call(this, name);
    this.age = age;
}

Child.prototype = Object.create(Parent.prototype, {
    constructor: {
        value: Child,
        enumerable: false,
        writable: true,
        configurable: true
    }
});

var child1 = new Child('Tom', 18);
child1.colors.push('black');
console.log(child1.colors);  // ['red', 'green', 'blue', 'black']
child1.sayName();  // Tom

var child2 = new Child('Jerry', 20);    
console.log(child2.colors);  // ['red', 'green', 'blue']
child2.sayName();  // Jerry

上述代码中,我们在子类原型中使用Object.create()方法创建了一个父类原型的副本,并通过Object.create()的第二个参数重写了子类原型的constructor属性,从而使其指向了子类自身。由于Object.create()方法并不会调用父类构造函数,因此就避免了在子类原型中多次调用父类构造函数的问题。

寄生组合继承的优点是既继承了父类原型中的方法,又避免了在子类原型中多次调用父类构造函数的问题。缺点是实现较为复杂。

总之,JavaScript中实现继承的方法有很多种,每一种方法都有各自的优缺点。在实际开发中,我们应该根据具体情况选择合适的继承方式。

以上就是JavaScript如何实现继承的的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: JavaScript如何实现继承的

本文链接: https://www.lsjlt.com/news/207231.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript如何实现继承的
    JavaScript是一种面向对象的语言,而继承是面向对象编程的一个重要特性。在JavaScript中,继承的实现方式有多种,本文将介绍其中较为常见的几种方法。一、原型链继承原型链继承是JavaScript中最基本的一种继承方式,也是最常用...
    99+
    2023-05-14
  • javascript是如何实现继承的
    本篇内容介绍了“javascript是如何实现继承的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • 如何利用JavaScript 实现继承
    目录一、背景简介二、原型对象和对象的关系二、使用 prototype 和 proto 实现继承三、使用prototype和proto实现继承四、通过原型链访问对象的方法和属性五、其他...
    99+
    2022-11-13
  • 原生Javascript如何实现继承
    这篇文章将为大家详细讲解有关原生Javascript如何实现继承,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言最近在复习javascript的一些基础知识,为开启新的征程做准备。所以开始记录一些自己学...
    99+
    2023-06-20
  • JavaScript继承怎么实现
    小编给大家分享一下JavaScript继承怎么实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!ES6之前,JavaScript...
    99+
    2022-10-19
  • JavaScript怎样实现继承
    这篇文章给大家分享的是有关JavaScript怎样实现继承的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。继承是面向对象编程中又一非常重要的概念,JavaScript支持实现继承,...
    99+
    2022-10-19
  • Javascript怎么实现继承
    这篇文章主要介绍“Javascript怎么实现继承”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Javascript怎么实现继承”文章能帮助大家解决问题。1、构造函...
    99+
    2022-10-19
  • 如何在JavaScript中实现简单的继承
    这篇文章主要讲解了“如何在JavaScript中实现简单的继承”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何在JavaScript中实现简单的继承”吧!...
    99+
    2022-10-19
  • javascript是怎么实现继承的
    这篇文章将为大家详细讲解有关javascript是怎么实现继承的,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 方法:1、利用原型让一个引用类...
    99+
    2022-10-19
  • javascript原型链中如何实现继承
    这篇文章将为大家详细讲解有关javascript原型链中如何实现继承,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:继承的几种方式:① 使用构造函数实现继承fun...
    99+
    2022-10-19
  • JavaScript继承与多继承实例讲解
    这篇文章主要介绍“JavaScript继承与多继承实例讲解”,在日常操作中,相信很多人在JavaScript继承与多继承实例讲解问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2022-10-19
  • javascript中怎么实现继承
    今天就跟大家聊聊有关javascript中怎么实现继承,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。对象冒充(多继承):a. 代码:function...
    99+
    2022-10-19
  • Javascript继承关系的实现方法
    本篇内容介绍了“Javascript继承关系的实现方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!说明JavaScript中的继承关系是通...
    99+
    2023-06-20
  • JavaScript如何实现寄生式组合继承
    小编给大家分享一下JavaScript如何实现寄生式组合继承,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!寄生式组合继承的实现?...
    99+
    2022-10-19
  • C++多继承(多重继承)的实现
    在前面的例子中,派生类都只有一个基类,称为单继承(Single Inheritance)。除此之外,C++也支持多继承(Multiple Inheritance),即一个派生类可以有...
    99+
    2023-05-16
    C++多继承 C++多重继承
  • JavaScript怎么实现继承功能
    这篇文章主要介绍“JavaScript怎么实现继承功能”,在日常操作中,相信很多人在JavaScript怎么实现继承功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java...
    99+
    2022-10-19
  • 怎么利用JavaScript 实现继承
    小编给大家分享一下怎么利用JavaScript 实现继承,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、背景简介JavaScript 在编程语言界是个...
    99+
    2023-06-29
  • 如何分析JavaScript的继承
    这篇文章将为大家详细讲解有关如何分析JavaScript的继承,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。原型链继承原理本质是重写原型对象,代之以一个新类...
    99+
    2022-10-19
  • 如何理解JavaScript继承
    这篇文章将为大家详细讲解有关如何理解JavaScript继承,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。背景继承给我们提供了一种优雅可复用的编码方式,继承...
    99+
    2022-10-19
  • Java中的继承如何实现
    本篇内容主要讲解“Java中的继承如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中的继承如何实现”吧!一. 继承众所周知,我们Java语言是一种面向对象的编程语言,每当我们提到J...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作