javascript中的继承如何实现_有哪些方法?

admin 百科 10
JavaScript继承主要通过原型链实现,ES6前无class语法,ES6引入class/extends语法糖但底层仍基于原型链和构造函数,常见方式有原型链继承、构造函数继承、组合继承和ES6 class继承。

javascript中的继承如何实现_有哪些方法?-第1张图片-佛山资讯网

JavaScript 中的继承主要通过原型链实现,没有传统面向对象语言中的 class 继承语法(ES6 之前),但 ES6 引入了 classextends 语法糖,底层仍是基于原型链和构造函数。常见实现方式有以下几种:

1. 原型链继承

让子构造函数的 prototype 指向父构造函数的一个实例。

优点:简单,能复用父类方法;
缺点:所有子实例共享父类实例的引用属性,无法向父构造函数传参。

示例:

立即学习“Java免费学习笔记(深入)”;

function Animal(name) {
  this.name = name;
  this.colors = ['black', 'white'];
}
Animal.prototype.say = function() {
  return `I'm ${this.name}`;
};

function Dog() {}
Dog.prototype = new Animal(); // 关键:继承原型
Dog.prototype.constructor = Dog;

const d1 = new Dog();
const d2 = new Dog();
d1.colors.push('brown');
console.log(d2.colors); // ['black', 'white', 'brown'] ← 共享了引用类型

登录后复制

2. 构造函数继承(借用构造函数)

在子构造函数中用 callapply 调用父构造函数。

优点:避免引用属性共享,支持传参;
缺点:只能继承实例属性/方法,无法复用父类原型上的方法。

示例:

立即学习“Java免费学习笔记(深入)”;

function Animal(name) {
  this.name = name;
  this.colors = ['black', 'white'];
}
Animal.prototype.say = function() {
  return `I'm ${this.name}`;
};

function Dog(name, breed) {
  Animal.call(this, name); // 关键:继承实例属性
  this.breed = breed;
}

const d = new Dog('Xiaohei', 'Shepherd');
console.log(d.name); // 'Xiaohei'
console.log(d.say); // undefined ← 原型方法没被继承

登录后复制

3. 组合继承(最常用)

结合前两种:原型链继承方法 + 构造函数继承属性。

标签: javascript es6 java js app 工具 ai

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~