首页 > web前端 > js教程 > 正文

javascript如何实现继承_ES6的class与原型继承有什么区别?

狼影
发布: 2025-12-20 09:50:39
原创
845人浏览过
ES6 的 class 是原型继承的语法糖,本质未改变继承机制,仍依赖原型链;通过 extends 和 super 实现继承,而 ES5 需手动操作 prototype 和 constructor;两者底层结构一致,但 class 写法更清晰、可读性更高。

javascript如何实现继承_es6的class与原型继承有什么区别?

ES6 的 class 本质是原型继承的语法糖,它没有引入新的继承机制,只是让基于原型的继承写起来更清晰、更接近传统面向对象语言的风格。真正起作用的,仍然是 JavaScript 底层的原型链([[Prototype]])。

class 实现继承:用 extends + super

使用 class 实现继承非常直观:

  • 子类通过 extends 关键字继承父类
  • 构造函数中必须调用 super(),否则无法访问 this
  • super 既可调用父类构造函数,也可访问父类方法(如 super.method()

示例:

class Animal {
  constructor(name) {
    this.name = name;
  }
  speak() {
    console.log(`${this.name} makes a sound.`);
  }
}

class Dog extends Animal {
  constructor(name, breed) {
    super(name); // 必须先调用
    this.breed = breed;
  }
  bark() {
    console.log(`${this.name} barks!`);
  }
}

const dog = new Dog('Max', 'Golden');
dog.speak(); // Max makes a sound.(继承自 Animal)
dog.bark();  // Max barks!
登录后复制

原型继承:手动操作 prototype 和 constructor

在 ES5 及之前,继承靠的是显式设置原型链和修正构造器:

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

  • Object.create(Parent.prototype) 设置子类原型
  • 手动赋值 Child.prototype.constructor = Child,否则 constructor 指向错误
  • 在子类构造函数中用 Parent.call(this, ...) 借用父类构造逻辑

示例:

function Animal(name) {
  this.name = name;
}
Animal.prototype.speak = function() {
  console.log(`${this.name} makes a sound.`);
};

function Dog(name, breed) {
  Animal.call(this, name); // 借用构造
  this.breed = breed;
}
Dog.prototype = Object.create(Animal.prototype); // 建立原型链
Dog.prototype.constructor = Dog; // 修复 constructor

Dog.prototype.bark = function() {
  console.log(`${this.name} barks!`);
};
登录后复制

核心区别:写法、可读性与底层一致性

写法上class 是声明式、结构化语法;原型继承是命令式、需手动维护原型链。

pollinations
pollinations

属于你的个性化媒体引擎

pollinations 247
查看详情 pollinations

可读性上class 更易理解继承关系和执行顺序(比如 super() 强制调用位置),而原型方式容易遗漏 constructor 修复或 call 步骤,导致隐性 bug。

底层上:两者最终都生成相同的原型链结构。例如 Dog.prototype.__proto__ === Animal.prototype 在两种方式下都为 true

限制上class 内部方法默认不可枚举(for...in 不会遍历到),而手动挂载到 prototype 上的方法默认可枚举(除非显式设 enumerable: false)。

注意事项:class 并非“真类”,仍受原型规则约束

class 不是 Java/C++ 那样的类,它不能被实例化为“类型”本身,也不能实现多继承。所有行为依然依赖原型查找:

  • 方法调用时,引擎仍沿 obj.__proto__ → Constructor.prototype → ... → Object.prototype 查找
  • 静态方法(static)实际定义在类本身(即构造函数)上,而非其 prototype
  • 子类的 super 在方法内部指向父类的 prototype,本质仍是原型访问

所以,理解原型链仍是掌握 JavaScript 继承的关键——class 只是让你少写几行容易出错的代码。

以上就是javascript如何实现继承_ES6的class与原型继承有什么区别?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号