我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript中继承的优缺点有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript中继承的优缺点有哪些

这篇文章给大家分享的是有关JavaScript中继承的优缺点有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

本文讲解JavaScript各种继承方式和优缺点。

但是注意:

这篇文章更像是笔记,哎,再让我感叹一句:《JavaScript高级程序设计》写得真是太好了!

1、原型链继承

function Parent () {      this.name = 'kevin';  }  Parent.prototype.getName = function () {      console.log(this.name);  }  function Child () {  }  Child.prototype = new Parent();   var child1 = new Child();  console.log(child1.getName()) // kevin

问题:

1、引用类型的属性被所有实例共享,举个例子:

function Parent () {      this.names = ['kevin', 'daisy'];  }  function Child () {  }  Child.prototype = new Parent();  var child1 = new Child();  child1.names.push('yayu');  console.log(child1.names); // ["kevin", "daisy", "yayu"]  var child2 = new Child();  console.log(child2.names); // ["kevin", "daisy", "yayu"]

2、在创建 Child 的实例时,不能向Parent传参

2、借用构造函数(经典继承)

function Parent () {      this.names = ['kevin', 'daisy'];  }  function Child () {      Parent.call(this);  }  var child1 = new Child();  child1.names.push('yayu');  console.log(child1.names); // ["kevin", "daisy", "yayu"]  var child2 = new Child();  console.log(child2.names); // ["kevin", "daisy"]

优点:

1、避免了引用类型的属性被所有实例共享

2、可以在 Child 中向 Parent 传参

举个例子:

function Parent (name) {      this.name = name;  }  function Child (name) {      Parent.call(this, name);  }  var child1 = new Child('kevin');  console.log(child1.name); // kevin  var child2 = new Child('daisy');  console.log(child2.name); // daisy

缺点:

方法都在构造函数中定义,每次创建实例都会创建一遍方法。

3、组合继承

原型链继承和经典继承双剑合璧。

function Parent (name) {      this.name = name;      this.colors = ['red', 'blue', 'green'];  }  Parent.prototype.getName = function () {      console.log(this.name)  }  function Child (name, age) {      Parent.call(this, name);        this.age = age;  }  Child.prototype = new Parent();  ChildChild.prototype.constructor = Child;  var child1 = new Child('kevin', '18');  child1.colors.push('black');  console.log(child1.name); // kevin  console.log(child1.age); // 18  console.log(child1.colors); // ["red", "blue", "green", "black"]  var child2 = new Child('daisy', '20');  console.log(child2.name); // daisy  console.log(child2.age); // 20  console.log(child2.colors); // ["red", "blue", "green"]

优点:融合原型链继承和构造函数的优点,是 JavaScript 中最常用的继承模式。

4、原型式继承

function createObj(o) {      function F(){}      F.prototype = o;      return new F();  }

就是 ES5 Object.create 的模拟实现,将传入的对象作为创建的对象的原型。

缺点:

包含引用类型的属性值始终都会共享相应的值,这点跟原型链继承一样。

var person = {      name: 'kevin',      friends: ['daisy', 'kelly']  }  var person1 = createObj(person);  var person2 = createObj(person);  person1.name = 'person1';  console.log(person2.name); // kevin  person1.firends.push('taylor');  console.log(person2.friends); // ["daisy", "kelly", "taylor"]

注意:修改person1.name的值,person2.name的值并未发生改变,并不是因为person1和person2有独立的 name 值,而是因为person1.name = 'person1',给person1添加了 name 值,并非修改了原型上的 name 值。

5、寄生式继承

创建一个仅用于封装继承过程的函数,该函数在内部以某种形式来做增强对象,最后返回对象。

function createObj (o) {      var clone = Object.create(o);      clone.sayName = function () {          console.log('hi');      }      return clone;  }

缺点:跟借用构造函数模式一样,每次创建对象都会创建一遍方法。

6、寄生组合式继承

为了方便大家阅读,在这里重复一下组合继承的代码:

function Parent (name) {      this.name = name;      this.colors = ['red', 'blue', 'green'];  }  Parent.prototype.getName = function () {      console.log(this.name)  }  function Child (name, age) {      Parent.call(this, name);      this.age = age;  }  Child.prototype = new Parent();  var child1 = new Child('kevin', '18');  console.log(child1)

组合继承最大的缺点是会调用两次父构造函数。

一次是设置子类型实例的原型的时候:

Child.prototype = new Parent();

一次在创建子类型实例的时候:

var child1 = new Child('kevin', '18');

回想下 new 的模拟实现,其实在这句中,我们会执行:

Parent.call(this, name);

在这里,我们又会调用了一次 Parent 构造函数。

所以,在这个例子中,如果我们打印 child1 对象,我们会发现 Child.prototype 和 child1 都有一个属性为colors,属性值为['red', 'blue', 'green']。

那么我们该如何精益求精,避免这一次重复调用呢?

如果我们不使用 Child.prototype = new Parent() ,而是间接的让 Child.prototype 访问到 Parent.prototype 呢?

看看如何实现:

function Parent (name) {      this.name = name;      this.colors = ['red', 'blue', 'green'];  }  Parent.prototype.getName = function () {      console.log(this.name)  }  function Child (name, age) {      Parent.call(this, name);      this.age = age;  }  // 关键的三步  var F = function () {};  F.prototype = Parent.prototype;  Child.prototype = new F();  var child1 = new Child('kevin', '18');  console.log(child1);

最后我们封装一下这个继承方法:

function object(o) {      function F() {}      F.prototype = o;      return new F();  }  function prototype(child, parent) {      var prototype = object(parent.prototype);      prototype.constructor = child;      child.prototype = prototype;  }  // 当我们使用的时候:  prototype(Child, Parent);

引用《JavaScript高级程序设计》中对寄生组合式继承的夸赞就是:

这种方式的高效率体现它只调用了一次 Parent 构造函数,并且因此避免了在 Parent.prototype 上面创建不必要的、多余的属性。与此同时,原型链还能保持不变;因此,还能够正常使用 instanceof 和 isPrototypeOf。开发人员普遍认为寄生组合式继承是引用类型最理想的继承范式。

感谢各位的阅读!关于“JavaScript中继承的优缺点有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript中继承的优缺点有哪些

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

下载Word文档

猜你喜欢

Java多继承的优点有哪些

Java不支持多继承,但是可以通过接口实现多继承的一些优点包括:1. 代码重用:通过多个接口可以在一个类中实现不同的功能,避免了代码的重复编写,提高了代码的可维护性和可读性。2. 灵活性:通过接口,一个类可以实现多个不同的功能,可以根据需要
2023-09-14

java中继承的优缺点对比

这篇文章将为大家详细讲解有关java中继承的优缺点对比,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实
2023-06-14

JavaScript中有哪些继承的方法

这篇文章将为大家详细讲解有关JavaScript中有哪些继承的方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1. 什么是继承继承: 首先继承是一种关系,类(class)与类之间的关系,J
2023-06-15

javascript中有哪些继承形式

本篇文章为大家展示了javascript中有哪些继承形式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Js的继承大体上就是两种:对象冒充、原型方式。这两种方式各有优点和缺陷,这里我先列举出来,再从底
2023-06-14

java继承的优缺点是什么

这篇“java继承的优缺点是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“java继承的优缺点是什么”文章吧。1、优点提
2023-06-30

javascript继承的方法有哪些

这篇文章将为大家详细讲解有关javascript继承的方法有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。javascript继承的6种方法:1、原型链继承,其重点是让新实例的原型等于父类的实例;2、
2023-06-14

Java的继承有哪些特点

本篇内容主要讲解“Java的继承有哪些特点”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java的继承有哪些特点”吧!继承:把多个类相同的内容提取到另外一个类中,然后使用关键字extends来实
2023-06-26

PHP继承特点有哪些

这篇文章主要介绍了PHP继承特点有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 定义:PHP继承与其他纯面向对象(从设计之初就完全由面向对象思维支配)编程语言是有一些
2023-06-06

python多继承的特点有哪些

多继承允许一个类同时继承多个父类,从而可以获得多个父类的属性和方法。如果多个父类中有相同的属性或方法,子类在调用时会按照继承的顺序优先调用排在前面的父类的属性或方法。多继承可以实现代码的复用,避免重复编写相同的代码。多继承也可能导致代码的复
python多继承的特点有哪些
2024-03-05

Java继承的知识点有哪些

今天小编给大家分享一下Java继承的知识点有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。继承继承的介绍继承是java面
2023-06-29

javascript array数组有哪些优缺点

JavaScript中的数组(Array)具有以下优点和缺点:优点:1. 灵活性:JavaScript数组可以包含不同类型的数据(字符串、数字、对象等),并且可以动态地增加或删除元素。2. 高效的索引和搜索:通过索引访问数组元素非常快速,因
2023-10-11

javascript继承实现的方式有哪些

本文小编为大家详细介绍“javascript继承实现的方式有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“javascript继承实现的方式有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。什么是继承用官
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录