当前位置:首页 > JavaScript

实现继承 js

2026-02-02 04:59:44JavaScript

原型链继承

通过原型链实现继承是 JavaScript 中最基础的继承方式。子类的原型对象指向父类的实例,从而继承父类的属性和方法。

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

function Child() {}
Child.prototype = new Parent();

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

构造函数继承

使用 call 或 apply 方法在子类构造函数中调用父类构造函数,实现属性继承。这种方式不会继承父类原型上的方法。

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

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

组合继承

结合原型链继承和构造函数继承的优点,既继承原型方法又继承实例属性。这是最常用的继承方式。

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

function Child(name, age) {
  Parent.call(this, name);
  this.age = age;
}
Child.prototype = new Parent();
Child.prototype.constructor = Child;

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

原型式继承

基于已有对象创建新对象,使用 Object.create() 方法实现。适合不需要单独构造函数的场景。

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

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

寄生式继承

在原型式继承基础上增强对象,添加额外方法。这种方式类似于工厂模式。

function createChild(parent) {
  const child = Object.create(parent);
  child.sayAge = function() {
    console.log(this.age);
  };
  return child;
}

const parent = { name: 'parent' };
const child = createChild(parent);
child.age = 10;
child.sayAge(); // 输出: 10

寄生组合式继承

最理想的继承方式,避免了组合继承中调用两次父类构造函数的问题。通过寄生方式继承原型,通过构造函数继承实例属性。

function inheritPrototype(child, parent) {
  const prototype = Object.create(parent.prototype);
  prototype.constructor = child;
  child.prototype = prototype;
}

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

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

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

ES6 Class 继承

使用 ES6 的 class 和 extends 关键字实现继承,语法更简洁,底层仍然是基于原型链的实现。

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

class Child extends Parent {
  constructor(name, age) {
    super(name);
    this.age = age;
  }
}

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

实现继承 js

标签: js
分享给朋友:

相关文章

js实现分页

js实现分页

分页的基本实现思路 在JavaScript中实现分页功能通常需要结合前端和后端逻辑。前端负责渲染分页控件和处理用户交互,后端负责提供分页数据。 前端分页实现 纯前端分页适用于数据量较小的情况,可以…

jquery.js

jquery.js

jQuery 是一个快速、简洁的 JavaScript 库,简化了 HTML 文档遍历、事件处理、动画设计和 Ajax 交互等操作。以下是关于 jQuery.js 的核心信息和使用方法: 获取…

js实现类

js实现类

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

js实现复制到剪贴板

js实现复制到剪贴板

使用document.execCommand方法(传统方式,已废弃但部分浏览器仍支持) 该方法适用于旧版浏览器,但已被标记为废弃。执行前需确保文本已被选中: function copyToClipb…

js实现预览

js实现预览

文件上传预览实现 使用JavaScript实现文件上传预览功能,可以通过FileReader对象读取文件内容并显示预览。以下代码支持图片、文本和PDF文件的预览: // HTML部分需要包含…

jquery js

jquery js

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