当前位置:首页 > JavaScript

js 实现 extends

2026-03-14 08:50:36JavaScript

实现 JavaScript 中的继承(extends)

在 JavaScript 中,可以通过多种方式实现继承。以下是几种常见的方法:

原型链继承

通过将子类的原型指向父类的实例来实现继承。

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

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

function Child() {
  this.name = 'Child';
}

Child.prototype = new Parent();
const child = new Child();
child.sayName(); // 输出 'Child'

构造函数继承

在子类构造函数中调用父类构造函数,使用 callapply 方法。

js 实现 extends

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

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

function Child(name) {
  Parent.call(this, name);
}

const child = new Child('Child');
child.sayName(); // 报错,无法继承父类原型方法

组合继承

结合原型链继承和构造函数继承,解决构造函数继承无法继承原型方法的问题。

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

Parent.prototype.sayName = 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.sayName(); // 输出 'Child'

原型式继承

使用 Object.create 方法实现继承。

js 实现 extends

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

const child = Object.create(parent);
child.name = 'Child';
child.sayName(); // 输出 'Child'

寄生组合式继承

优化组合继承,避免重复调用父类构造函数。

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

Parent.prototype.sayName = 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.sayName(); // 输出 'Child'

ES6 的 class 和 extends

使用 ES6 的 classextends 语法糖实现继承。

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

  sayName() {
    console.log(this.name);
  }
}

class Child extends Parent {
  constructor(name) {
    super(name);
  }
}

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

注意事项

  • 原型链继承会导致所有子类实例共享父类实例的属性,可能导致意外修改。
  • 构造函数继承无法继承父类原型上的方法。
  • 组合继承会调用两次父类构造函数,可能影响性能。
  • 寄生组合式继承是目前最理想的继承方式。
  • ES6 的 classextends 语法简洁,但本质仍是基于原型的继承。

标签: jsextends
分享给朋友:

相关文章

js实现文件下载

js实现文件下载

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

js实现类

js实现类

JavaScript 实现类的几种方式 JavaScript 是一种基于原型的语言,但在 ES6 之后引入了 class 语法糖,使得实现类更加直观。以下是几种常见的实现方式: 使用构造函数 传统的…

js实现图

js实现图

JavaScript 实现图的常用方法 在 JavaScript 中,图(Graph)可以通过多种方式实现,常见的包括邻接表(Adjacency List)和邻接矩阵(Adjacency Matrix…

js实现求导

js实现求导

实现数值求导的方法 在JavaScript中实现求导通常采用数值方法,因为JavaScript不是符号计算语言。以下是常见的数值微分方法: 中心差分法 中心差分法提供较高精度的导数近似: func…

利用js实现

利用js实现

使用 JavaScript 实现 在 JavaScript 中,可以通过多种方式实现功能,具体取决于需求。以下是几种常见的方法: 方法一:使用原生 JavaScript // 示例代码…

链表实现js

链表实现js

链表的基本概念 链表是一种线性数据结构,由一系列节点组成,每个节点包含数据和一个指向下一个节点的指针(单向链表)或两个指针(双向链表)。与数组不同,链表在内存中非连续存储,插入和删除操作更高效,但随机…