当前位置:首页 > JavaScript

js继承如何实现的

2026-03-01 00:55:15JavaScript

原型链继承

通过将子类的原型指向父类的实例实现继承。子类实例能够访问父类原型上的属性和方法。

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'

缺点:父类引用类型属性会被所有子类实例共享,无法向父类构造函数传参。

构造函数继承

在子类构造函数中调用父类构造函数,使用call/apply改变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();

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

缺点:调用了两次父类构造函数,子类原型上会存在多余属性。

原型式继承

通过Object.create基于已有对象创建新对象,类似原型链继承的简化版。

js继承如何实现的

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

const child = Object.create(parent);
child.name = 'child';
child.say(); // 'child'

寄生式继承

在原型式继承基础上增强对象,添加额外方法。

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

寄生组合式继承

目前最理想的继承方式,只调用一次父类构造函数,保持原型链不变。

function inherit(Child, Parent) {
  const prototype = Object.create(Parent.prototype);
  prototype.constructor = Child;
  Child.prototype = prototype;
}

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

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

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

ES6 class继承

使用extends关键字实现类继承,语法更简洁。

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'

ES6继承实质是语法糖,底层仍使用寄生组合式继承。

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

相关文章

js实现分页

js实现分页

实现分页的基本思路 分页功能通常需要处理数据分割、页码生成和用户交互。核心逻辑包括计算总页数、根据当前页截取数据、渲染页码按钮等。 前端分页实现(静态数据) 假设已有全部数据,仅需前端分页展示:…

vue.js实现轮播

vue.js实现轮播

Vue.js 实现轮播功能 使用第三方库(推荐) Vue.js 生态中有许多成熟的轮播组件库,例如 vue-awesome-swiper 或 swiper,它们功能丰富且易于集成。 安装 swipe…

js实现vue

js实现vue

Vue.js 简介 Vue.js 是一个渐进式 JavaScript 框架,用于构建用户界面。其核心库专注于视图层,易于与其他库或现有项目整合。 实现 Vue.js 的基本步骤 安装 Vue.j…

js实现选项卡

js实现选项卡

实现选项卡的基本思路 选项卡通常由一组标签和对应的内容面板组成。点击标签时,显示对应的内容面板,隐藏其他面板。实现这一效果需要结合HTML结构、CSS样式和JavaScript交互逻辑。 HTML结…

vue如何实现

vue如何实现

Vue 实现方法 Vue 提供了多种方式来实现功能,具体取决于需求。以下是一些常见场景的实现方法: 数据绑定 使用 v-model 指令实现双向数据绑定,适用于表单输入元素。在组件中可以通过 pro…

js实现论坛

js实现论坛

实现论坛的基本功能 使用JavaScript实现一个论坛需要结合前端和后端技术。前端可以使用React、Vue或Angular等框架,后端可以选择Node.js配合Express或Koa框架。数据库可…