【前端每日一题】 day3

JS的原型链如何实现继承,请写出一个例子

JavaScript中的原型链继承是通过原型(prototype)来实现的。每个对象都有一个原型(prototype),该原型又是一个对象,而这个对象又有自己的原型,以此类推,形成了一个原型链。当试图访问一个对象的属性或方法时,JavaScript会首先在该对象本身上查找,如果找不到,就会沿着原型链向上查找,直到找到相应的属性或方法,或者到达原型链的末端。

such as

javascript 复制代码
// 父类(超类)
function Animal(name) {
  this.name = name;
}

// 父类的方法
Animal.prototype.sayName = function() {
  console.log("My name is " + this.name);
};

// 子类(派生类)
function Dog(name, breed) {
  // 调用父类的构造函数
  Animal.call(this, name);
  this.breed = breed;
}

// 继承父类的原型
Dog.prototype = Object.create(Animal.prototype);

// 重设子类的构造函数,否则会指向父类
Dog.prototype.constructor = Dog;

// 子类的方法
Dog.prototype.bark = function() {
  console.log("Woof!");
};

// 创建一个实例
var myDog = new Dog("Max", "Labrador");

// 调用父类的方法
myDog.sayName(); // 输出:"My name is Max"

// 调用子类的方法
myDog.bark(); // 输出:"Woof!"

Animal 是一个父类,拥有一个属性 name 和一个方法 sayName。

Dog 是一个子类,通过调用父类的构造函数 Animal.call(this, name) 继承了父类的属性,并通过 Object.create(Animal.prototype) 继承了父类的方法。

在子类中,还可以定义自己的方法,比如 bark。

最后,通过创建 Dog 类的实例 myDog,我们可以看到实现了继承关系,并且可以调用父类和子类的方法。

相关推荐
(⊙o⊙)~哦1 小时前
JavaScript substring() 方法
前端
无心使然云中漫步1 小时前
GIS OGC之WMTS地图服务,通过Capabilities XML描述文档,获取matrixIds,origin,计算resolutions
前端·javascript
Bug缔造者2 小时前
Element-ui el-table 全局表格排序
前端·javascript·vue.js
xnian_2 小时前
解决ruoyi-vue-pro-master框架引入报错,启动报错问题
前端·javascript·vue.js
麒麟而非淇淋3 小时前
AJAX 入门 day1
前端·javascript·ajax
2401_858120533 小时前
深入理解MATLAB中的事件处理机制
前端·javascript·matlab
阿树梢3 小时前
【Vue】VueRouter路由
前端·javascript·vue.js
随笔写4 小时前
vue使用关于speak-tss插件的详细介绍
前端·javascript·vue.js
史努比.5 小时前
redis群集三种模式:主从复制、哨兵、集群
前端·bootstrap·html
快乐牌刀片885 小时前
web - JavaScript
开发语言·前端·javascript