答案:ES6的class语法基于原型机制,提供更清晰的面向对象编程方式,包括构造函数、继承、静态成员和getter/setter。1. 使用class定义类,constructor初始化属性,方法定义在原型上;2. 通过extends实现继承,子类需调用super()初始化父类;3. static定义静态方法或属性,属于类本身而非实例;4. getter/setter用于控制属性访问与赋值,常用于数据校验。

ES6 引入了 class 语法,让 JavaScript 的面向对象编程更接近传统语言(如 Java、C++),但其底层依然是基于原型(prototype)的机制。类和继承的实现更加清晰、易读。
1. JS 中 class 的基本用法
使用 class 关键字可以定义一个类。类中通过 constructor 定义构造函数,用于初始化实例属性。
class Person { constructor(name, age) { this.name = name; this.age = age; } sayHello() { console.log(`你好,我是${this.name}`); }}const p1 = new Person("小明", 25);p1.sayHello(); // 输出:你好,我是小明
说明:
constructor 是构造方法,创建实例时自动调用 方法之间不需要逗号分隔,也不是键值对形式 所有方法都定义在类的原型上(prototype)
2. 类的继承:extends 和 super
使用 extends 实现类的继承,子类可以继承父类的属性和方法。在子类的 constructor 中必须调用 super(),否则无法使用 this。
class Student extends Person { constructor(name, age, grade) { super(name, age); // 调用父类构造函数 this.grade = grade; } study() { console.log(`${this.name} 正在学习`); } // 可以重写父类方法 sayHello() { console.log(`学生说:我是${this.name},今年${this.age}岁`); }}const s1 = new Student("小红", 20, "大三");s1.sayHello(); // 学生说:我是小红,今年20岁s1.study(); // 小红 正在学习
关键点:
extends 表示继承自某个类 super() 必须在子类 constructor 中调用,用来初始化父类的 this super 也可以调用父类的其他方法,如 super.sayHello()
3. 静态方法与静态属性
使用 static 关键字定义静态方法或属性,它们属于类本身,而不是实例。
class MathUtils { static PI = 3.14159; static add(a, b) { return a + b; }}console.log(MathUtils.add(2, 3)); // 5console.log(MathUtils.PI); // 3.14159// 注意:不能通过实例调用静态方法const mu = new MathUtils();// mu.add(2, 3); // 错误:mu.add is not a function
静态方法常用于工具类或不需要实例化的功能。
4. getter 和 setter
可以在类中定义 getter 和 setter,用于控制属性的访问和赋值。
class BankAccount { constructor(balance) { this._balance = balance; // 私有化约定 } get balance() { return this._balance + " 元"; } set balance(amount) { if (amount < 0) { console.log("余额不能为负!"); return; } this._balance = amount; }}const account = new BankAccount(100);console.log(account.balance); // 100 元account.balance = -50; // 余额不能为负!account.balance = 200;console.log(account.balance); // 200 元
get 和 set 让你可以拦截属性的读写操作,增强数据安全性。
基本上就这些。class 让代码结构更清晰,继承更直观,是现代 JS 开发的推荐方式。虽然底层仍是原型链,但语法糖大大提升了开发体验。不复杂但容易忽略细节,比如 super 的调用时机和静态成员的访问方式。
以上就是JS类和继承怎么实现_JS ES6类class与继承机制使用教程的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1537489.html
微信扫一扫
支付宝扫一扫