当前位置:首页 > JavaScript

js如何实现继承

2026-04-03 18:31:10JavaScript

原型链继承

通过将子类的原型对象指向父类的实例实现继承。子类实例能够访问父类的属性和方法,但所有子类实例共享父类的引用属性,可能导致修改污染。

function Parent() {
  this.name = 'parent';
}
Parent.prototype.say = function() {
  console.log(this.name);
};

function Child() {}
Child.prototype = new Parent(); // 核心步骤

const child = new Child();
child.say(); // 输出 "parent"

构造函数继承

在子类构造函数中调用父类构造函数,使用callapply改变this指向。能解决引用属性共享问题,但无法继承父类原型上的方法。

function Parent(name) {
  this.name = name;
}

function Child(name) {
  Parent.call(this, name); // 核心步骤
}

const child = new Child('child');
console.log(child.name); // 输出 "child"

组合继承

结合原型链继承和构造函数继承,既保留原型链特性,又避免引用属性共享。需调用两次父类构造函数,可能造成性能损耗。

js如何实现继承

function Parent(name) {
  this.name = name;
}
Parent.prototype.say = function() {
  console.log(this.name);
};

function Child(name) {
  Parent.call(this, name); // 第一次调用
}
Child.prototype = new Parent(); // 第二次调用
Child.prototype.constructor = Child;

const child = new Child('child');
child.say(); // 输出 "child"

原型式继承

基于已有对象创建新对象,使用Object.create()实现。适合不需要单独构造函数的场景,但引用属性仍会被共享。

const parent = {
  name: 'parent',
  say: function() {
    console.log(this.name);
  }
};

const child = Object.create(parent); // 核心步骤
child.name = 'child';
child.say(); // 输出 "child"

寄生式继承

在原型式继承基础上增强对象,添加额外方法。适用于需要扩展对象的场景,但难以实现函数复用。

js如何实现继承

function createChild(parent) {
  const child = Object.create(parent);
  child.sayHi = function() {
    console.log('Hi');
  };
  return child;
}

const parent = { name: 'parent' };
const child = createChild(parent);

寄生组合式继承

目前最理想的继承方式,通过Object.create()减少父类构造函数的调用次数,同时保持原型链完整。

function Parent(name) {
  this.name = name;
}
Parent.prototype.say = function() {
  console.log(this.name);
};

function Child(name) {
  Parent.call(this, name);
}
Child.prototype = Object.create(Parent.prototype); // 核心步骤
Child.prototype.constructor = Child;

const child = new Child('child');
child.say(); // 输出 "child"

ES6 Class继承

使用extends关键字实现类继承,语法更简洁,底层仍基于原型链。支持super调用父类方法。

class Parent {
  constructor(name) {
    this.name = name;
  }
  say() {
    console.log(this.name);
  }
}

class Child extends Parent { // 核心步骤
  constructor(name) {
    super(name);
  }
}

const child = new Child('child');
child.say(); // 输出 "child"

标签: 如何实现js
分享给朋友:

相关文章

vue如何实现到期提醒

vue如何实现到期提醒

实现思路 在Vue中实现到期提醒功能,可以通过计算日期差、定时检查和通知用户三个核心步骤完成。需要结合Vue的响应式特性和JavaScript的日期处理能力。 计算日期差 使用JavaScript的…

如何实现vue表格联动

如何实现vue表格联动

实现 Vue 表格联动的方法 数据绑定与响应式更新 通过 Vue 的响应式特性,将多个表格的数据绑定到同一个数据源或计算属性。当一个表格的数据发生变化时,另一个表格会自动更新。例如: data()…

js实现文件下载

js实现文件下载

使用 a 标签下载文件 通过动态创建 a 标签并设置 download 属性实现文件下载。适用于已知文件 URL 或 Blob 数据的情况。 function downloadFile(url, f…

js实现全屏

js实现全屏

实现全屏的基本方法 使用JavaScript实现全屏功能主要依赖Element.requestFullscreen()方法。现代浏览器均支持此API,但不同浏览器可能需要添加前缀。 // 触发全屏…

js 实现分页

js 实现分页

实现分页的基本逻辑 分页功能通常需要后端返回数据总量或总页数,前端根据当前页码和每页条数截取对应数据。以下是一个基于JavaScript的简单分页实现方案: 前端分页实现 假设已有从后端获取的完整数…

js jquery

js jquery

jQuery 简介 jQuery 是一个快速、简洁的 JavaScript 库,简化了 HTML 文档遍历、事件处理、动画设计和 Ajax 交互。它兼容多种浏览器,提供易于使用的 API,使开发者能够…