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

JavaScript 中的继承主要通过原型链实现,没有传统面向对象语言中的 class 继承语法(ES6 之前),但 ES6 引入了 class 和 extends 语法糖,底层仍是基于原型链和构造函数。常见实现方式有以下几种:
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. 构造函数继承(借用构造函数)
在子构造函数中用 call 或 apply 调用父构造函数。
优点:避免引用属性共享,支持传参;
缺点:只能继承实例属性/方法,无法复用父类原型上的方法。
示例:
立即学习“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
还木有评论哦,快来抢沙发吧~