当前位置: 首页 > news >正文

JS中实现继承

1.使用call实现继承(不推荐)

function Animal(name) {this.name = name;this.run = function() {console.log(this.name, "跑");}
}
function Dog(name) {// 继承Animal.call(this, name);this.sleep = function() {console.log(this.name, "睡");}
}
dog = new Dog("旺财");
dog.run();    // 旺财 跑
dog.sleep();  // 旺财 睡

(1)优点

  • 父类的构造函数在子类构造函数中调用,可以向父类构造函数传递参数;
  • 子类实例化后,不会受到父类实例化后修改属性的影响。

(2)缺点

  • 子类实例无法通过instanceof判断出父类的实例;
  • 无法继承父类原型链上的属性和方法,只能继承父类的实例属性和方法;
  • 子类实例无法通过instanceof判断出父类的实例;

2.使用原型实现继承(不推荐)

function Animal(){this.run = function() {console.log(this.name, "跑");}
}
function Dog(name){this.name = name;this.sleep = function() {console.log(this.name, "睡");}
}
// 继承
Dog.prototype = new Animal();dog = new Dog("大黄");
dog.sleep(); // 大黄 睡
dog.run();   // 大黄 跑

优点:

  • 子类实例可以通过instanceof判断出父类的实例;
  • 每个子类实例共享父类的属性和方法,节省内存。

缺点:

  • 无法继承父类原型链上的属性和方法,只能继承父类的实例属性和方法;
  • 子类实例共享父类的属性和方法时,如果修改了属性值,其他实例也会受到影响;
  • 无法传递参数给父类的构造函数,父类的属性只能通过子类的构造函数传递。

3.上述两种方法结合(推荐)

// 1.定义一个父类
function Animal(name) {this.name = name;
}// 2.定义父类的原型方法
Animal.prototype.speak = function() {console.log(this.name + ' makes a noise.');
};// 3.定义一个子类
function Dog(name, breed) {Animal.call(this, name); // 调用父类的构造函数this.breed = breed;
}// 4,将子类的原型设置为父类的一个实例,实现继承
Dog.prototype = Object.create(Animal.prototype);
Dog.prototype.constructor = Dog;// 5.定义子类的原型方法
Dog.prototype.bark = function() {console.log(this.name + ' barks.');
};// 创建一个Dog对象并调用其方法
var myDog = new Dog('Buddy', 'Labrador');
myDog.speak(); // Buddy makes a noise.
myDog.bark(); // Buddy barks.

优点:

  1. 子类实例可以通过instanceof判断出父类的实例;
  2. 子类即拥有父类构造函数中的属性和方法,也有父类prototype中的属性和方法;
http://www.lryc.cn/news/295358.html

相关文章:

  • spring boot学习第九篇:操作mongo的集合和集合中的数据
  • momentJs推导日历组件
  • Linux C/C++ 原始套接字:打造链路层ping实现
  • TCP 粘包/拆包
  • 【Spring Boot 3】应用启动执行特定逻辑
  • 设计模式(行为型模式)观察者模式
  • Windows 版Oracle 数据库(安装)详细过程
  • 编程实例分享,计费系统一定要安装灯光控制吗?佳易王计时计费管理系统软件V18.0教程说明
  • 【webpack】优化提升
  • 视频无损放大修复工具Topaz Video AI 新手入门教程
  • 《向量数据库指南》——Milvus Cloud 「部署」:简化部署一直在路上
  • 使用x86架构+Nvidia消费显卡12G显存,搭建智能终端,将大模型本地化部署,说不定是未来方向,开源交互机器人设计
  • 关于RabbitMQ面试题汇总
  • GoogleTest 单元测试
  • Mac利用brew安装mysql并设置初始密码
  • R语言入门笔记2.2
  • 一般系统的请求认证授权思路【gateway网关+jwt+redis+请求头httpheader】
  • c# 正则表达式 帮助类
  • 告别mPDF迎来TCPDF和中文打印遇到的问题
  • mysql 多数据源
  • uniapp 使用renderjs引入echarts
  • hr最讨厌这6种应届生简历❌
  • 【Linux笔记】文件系统与软硬链接
  • vue3(笔记)
  • Java面向对象 this
  • 阿里云游戏服务器租用价格表,2024最新报价
  • 2-1 动手学深度学习v2-Softmax回归-笔记
  • laravel distinct查询问题,laravel子查询写法
  • AI助力农作物自动采摘,基于DETR(DEtection TRansformer)开发构建作物生产场景下番茄采摘检测计数分析系统
  • C语言——字符串大小写互换