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

相关文章

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

Spring中配置ContextLoaderListener方式

《Spring中配置ContextLoaderListener方式》:本文主要介绍Spring中配置ContextLoaderListener方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录Spring中配置ContextLoaderLishttp://www.chinasem.cntene

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St