首页 > 其他分享 >web前端tips:js继承——寄生式继承

web前端tips:js继承——寄生式继承

时间:2023-09-28 16:01:20浏览次数:27  
标签:web 寄生 继承 创建 型式 js 对象 child

输入图片描述

上篇文章给大家分享了 js继承中的 原型式继承

web 前端 tips:js 继承 —— 原型式继承

今天给大家分享一下 js 继承中的 寄生式继承

寄生式继承

寄生式继承(Parasitic Inheritance)是一种基于原型式的继承方式,它通过创建一个仅用于封装继承过程的函数,该函数在内部调用原型式继承创建一个对象,然后增强该对象,最后返回这个对象。

基本步骤:

  1. 创建一个用于封装继承过程的函数,我们称之为"寄生函数"。
  2. 在寄生函数内部,通过某种方式创建一个新对象,这个新对象将作为继承对象。
  3. 在寄生函数内部,可以为新对象添加需要继承的属性和方法。
  4. 最后,返回这个新对象作为继承结果
// 1 寄生式继承函数
function createChild(parent) {
  // 2 通过原型式继承创建一个新对象
  var child = Object.create(parent);
  // 3 增强新对象
  child.sayGoodBye = function() {
    console.log('GoodBye: ' + this.name)
  }
  // 4
  return child
}

var parent = {
  name: "Parent",
  sayHello: function() {
    console.log("Hello, " + this.name + "!");
  }
};

// 使用寄生式继承创建子对象
var child = createChild(parent)
child.name = 'John'

child.sayHello(); // Hello, John!
child.sayGoodBye(); // Goodbye, John

通过这种方式,子对象child可以继承父对象Parent的属性和方法,并且还可以增加自己的方法。

需要注意的是,寄生式继承与原型式继承类似,子对象通过继承来创建,但是可以在创建过程中添加额外的属性和方法。

优点

  • 简单易懂:寄生式继承相对于其他继承方式来说,非常简单易懂,不需要理解过多的继承机制和语法。
  • 灵活性:寄生式继承允许在继承过程中增加额外的功能,可以在新对象中添加新的属性和方法,或者对已有的属性和方法进行修改和增强,从而满足特定的需求。
  • 可复用性:可以基于已有对象创建新对象,并对新对象进行修改,从而实现代码的复用。

缺点

  • 对象间关系复杂:同时使用原型式继承和寄生式继承时,对象间的继承关系可能变得复杂难以理解,维护和调试时可能会增加困难。
  • 内存消耗较大:寄生式继承在创建新对象时,需要为每个对象都创建一个新的副本,这会占用较多的内存空间,特别是在需要创建大量对象时可能会导致性能问题。
  • 对象识别困难:在寄生式继承中,新创建的对象与原型对象之间的关系并不直观,可能会导致一些难以追踪的问题,如对象属性的重复定义或覆盖等。

总的来说,虽然寄生式继承具有一定的灵活性和可用性,但由于上述缺点的存在,它并不是一个被广泛使用的继承方式。在实际开发中,需要权衡其优缺点,根据具体情况选择合适的继承方式。

结语

牵手 持续为你分享各类知识和软件 ,欢迎访问、关注、讨论 并留下你的小心心❤

标签:web,寄生,继承,创建,型式,js,对象,child
From: https://blog.51cto.com/u_15994752/7640391

相关文章

  • nodejs学习01-安装
    参考:nodeJS压缩版安装与配置 注意:最新版本不支持win7有问题,我win7用的 node-v11.15.0-win-x86历史版本下载:https://registry.npmmirror.com/binary.html?path=node/......
  • Web Services使用SOAP Header
    https://blog.csdn.net/szg3827/article/details/2232809https://www.cnblogs.com/zxh1919/p/7670110.html许多的公司都有自己的web服务来支撑自己系统内的运营逻辑,并且是非公开的,那么如何对自己的web服务进行验证呢?不可能任何一个知道你的webserviceurl的人都可以去调用你的......
  • 对象转JSON 遇到的BigDecimal 科学计数法的问题,json转化字段单独处理
    问题描述:项目需要发送JSON数据,BigDecimal转成json仍然显示科学计数法,如果使用BigDecimai的toPlainString()需要将数据格式转为String,所以找了一下fastjson的自定义序列化内容,记录一下,以免以后忘记解决方案:方案一:JSONObject.toJSONString(vo,SerializerFeature.WriteBigDecimalA......
  • 直播平台开发,纯时间比较(时分),不含日期,js前端比较
    直播平台开发,纯时间比较(时分),不含日期,js前端比较//ajax请求后返回的数据success:function(data){for(vari=0;i<data.length;i++){varrows=data[i];varrowTimeBegin=(parseInt(((rows.timeBegin).split(":"))[0]))*60*60+(parseInt(((rows.timeBegin).split(":"......
  • weblogic乱码报错解决思路
    目录1.集群备份weblogic虚拟机快照备份2.查看主节点控制台面板状态3.尝试启动程序失败4.查看162.主节点日志5.发现程序中乱码6.修改乱码名称7.尝试启动,新的报错还是显示乱码8.修改乱码9.点击更新程序,继续报错9.1依然是乱码10.更新,程序部署路径,换新程序,11.删除程序,处理程序中的乱码......
  • webstorage
    title:Web存储方式tags:-WebStorage-htmlcategories:干垃圾keywords:Web存储方式description:Web存储方式top:repost:truehot:trueothers:date:2019-01-1719:30:07{%noteinfono-icon%}Web的几种存储方式介绍web存储方式有哪些?如下图,常见的浏览......
  • websocket
    title:Websocket简介tags:WebSocketcategories:干垃圾keywords:WebSocketdescription:Websocket简介top:repost:hot:others:date:2020-01-1113:13:13{%notewarningno-icon%}  随着网际网络的发展,传统的HTTP协议已经很难满足Web应用日益复杂的需求了......
  • 下载vue.js、element-plus的js和样式、locale.js、icon-vue.js
    一、下载vue.js地址:https://www.bootcdn.cn/vue/找到vue.global.js点击复制链接,在浏览器中打开,如下所示:二、下载element-plus的js和样式进入element-plus的官网:https://element-plus.org/zh-CN/点击指南点击安装1、下载样式:复制//unpkg.com/element-plus/dist/inde......
  • java.lang.IllegalStateException: javax.websocket.server.ServerContainer not avai
    spring项目能正常运行,但是单元测试报错错误原因注册WebSocket的Bean与springboot内带tomcat冲突解决办法1.注释该类里面的代码(不推荐)2.@springBootTest注解添加webEnvironment=SpringBootTest.WebEnvironment.RANDOM_PORT@SpringBootTest注解中,给出了webEnvironment参......
  • 前端js下载文件方式记录
    方式一:前端组装数据进行下载如下方式://创建数据vardata="Hello,world!";//将数据转换为Blob对象varblob=newBlob([data],{type:"text/plain;charset=utf-8"});//创建一个URL对象,指向Blob对象varurl=URL.createObjectURL(blob);//创建一个下......