js常用的继承方式

2024-09-04 21:18
文章标签 js 方式 常用 继承

本文主要是介绍js常用的继承方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.原型链继承

不考虑函数参数的情况下,我这样写

   function Animal(){this.family=['father','mother'];this.age=12;}function Cat(){}Cat.prototype=new Animal();var cat=new Cat();
//         console.log(cat.family);   //可以正常输出
//         console.log(cat.age);cat.family.push('sister');   //cat改变family属性console.log(cat.family);//改变已经体现var cat1=new Cat(); //创建第二个实例console.log(cat1.family);//也出现了“sister”,所有的实例都被改变,这显然不是我们想要的结果var animal=new Animal();console.log(animal.family);//父类Animal没有改变,由此说明只是Cat发生了永久改变,所有的new Cat()实例都将体现该变化
考虑接受参数的情况

  function Animal(age){this.family=['father','mother'];this.age=age;}function Cat(age){}Cat.prototype=new Animal();var cat=new Cat(12);console.log(cat.age);//undefined,参数传递失败,显然我们不能为每个实例单独传递参数


2.对象冒充

参数传递的问题,我们使用call(或者apply)解决

  function Animal(age){this.family=['father','mother'];this.age=age;}function Cat(cat_age){Animal.call(this,cat_age)//Cat的this指向Animal对象,并且将参数cat_age传递到Animal}var cat=new Cat(12);console.log(cat.age);//12,在使用call的情况下参数传递问题已经解决
再来看看这种方式有没有解决原型链继承中一个实例属性改变导致所有实例属性改变的问题

 function Animal(age){this.family=['father','mother'];this.age=age;}function Cat(cat_age){Animal.call(this,cat_age)//Cat的this指向Animal对象,并且将参数age传递到Animal}var cat=new Cat(12);cat.family.push('sister');console.log(cat.family);//father,mother,sistervar cat1=new Cat(12);console.log(cat1.family);//father,mother问题已经解决
这种方式实现的继承是不是完美无缺呢??看下面代码

function Animal(age){this.family=['father','mother'];this.age=age;this.getInfo=function(){return this.age+' '+this.family;}}function Cat(cat_age){Animal.call(this,cat_age)//Cat的this指向Animal对象,并且将参数age传递到Animal}var cat=new Cat(12);var cat1=new Cat(13);console.log(cat.getInfo());//12 father,motherconsole.log(cat1.getInfo());//13 father,motherconsole.log(cat.getInfo==cat1.getInfo);//false

说明两个实例调用的是不同的getInfo()函数,我们希望getInfo()函数是可以复用的,不需要创建多个,我们考虑用继承来解决这个问题

function Animal(age){this.family=['father','mother'];this.age=age;}Animal.prototype.getInfo=function(){return this.age+' '+this.family;}function Cat(cat_age){Animal.call(this,cat_age)//Cat的this指向Animal对象,并且将参数age传递到Animal}var cat=new Cat(12);var cat1=new Cat(13);console.log(cat.getInfo==cat1.getInfo);//trueconsole.log(cat.getInfo());//报错console.log(cat1.getInfo());//报错

说明cat和cat1访问不到Animal原型上的东西

那怎么解决呢??接下来学习没毛病的组合继承,这也是最常用的一种继承方式

3.组合继承

 function Animal(age){this.family=['father','mother'];this.age=age;}Animal.prototype.getInfo=function(){return this.age+' '+this.family;}function Cat(cat_age){Animal.call(this,cat_age)//Cat的this指向Animal对象,并且将参数age传递到Animal}Cat.prototype=new Animal();var cat=new Cat(12);var cat1=new Cat(13);console.log(cat.getInfo==cat1.getInfo);//trueconsole.log(cat.getInfo());//12 father,motherconsole.log(cat1.getInfo());//13 father,mother
好了,组合继承成功将原型链继承和对象冒充的缺陷弥补,并继承了他们所有优点,没毛病

这篇关于js常用的继承方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137052

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念