JavaScript继承本质是原型链,class只是构造函数语法糖;需用Object.create设置子类原型并修复constructor,子类构造函数中调用Parent.call(this)实现实例属性继承;ES6 class通过extends和super实现继承,底层仍操作原型链。

JavaScript 中的继承机制主要通过原型链(prototype chain)实现,ES6 引入的 class 语法只是构造函数的语法糖,本质仍基于原型——类定义最终会被编译为构造函数和原型操作。
原型链继承:最基础的实现方式
每个函数都有 prototype 属性,每个实例都有隐式原型 __proto__(指向其构造函数的 prototype)。继承就是让子类型的原型指向父类型的实例:
- 用
Object.create(Parent.prototype)设置子类原型,避免调用父构造函数产生冗余属性 - 手动修复
constructor指向,否则子类原型的constructor会指向父类 - 子类构造函数中需用
Parent.call(this, ...)借用父类初始化逻辑(实现“实例属性继承”)
ES6 class 继承:语法更简洁,底层仍是原型
class 不是全新面向对象模型,它只是包装了构造函数和原型操作:
-
class A {}等价于function A() {},且自动设为严格模式 -
class B extends A内部仍通过Object.setPrototypeOf(B.prototype, A.prototype)建立原型链 -
super()在子类构造器中必须调用,本质是执行A.call(this, ...) - 静态方法、getter/setter、私有字段(
#field)等也全部编译为原型或闭包/WeakMap 实现
组合继承与现代推荐方案
单纯原型链无法传参,单纯借用构造函数无法复用方法——经典组合继承(原型链 + call)曾是主流。现在更推荐:
标签: javascript es6 java typescript 浏览器 ai
还木有评论哦,快来抢沙发吧~