JavaScript ES6类的主要功能

标题JavaScript ES6类的主要功能

JavaScript ES6(ECMAScript 6)引入了类(Class)的概念,这是对JavaScript面向对象编程模型的一种更清晰、更简洁的语法糖。虽然在ES6之前,我们可以通过构造函数和原型链实现类似类的行为,但ES6中的类语法更加接近传统面向对象语言如Java或C#。

1.类声明:使用class关键字来定义一个类

复制代码
class Person {
  // ...
}

2.构造函数:类中定义的特殊方法constructor用于创建并初始化新实例

复制代码
class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }
}

3.实例属性和方法:在类内部可以定义实例属性和方法,这些将被所有类的实例共享

复制代码
class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }
  sayHello() {
    console.log(`Hi, I am ${this.name} and I am ${this.age} years old.`);
  }
}

4.静态属性和方法:使用static关键字定义的属性和方法属于类本身,而不是其任何实例。

复制代码
class Person {
  static species = "Human";
  static getSpecies() {
    return this.species;
  }
}
console.log(Person.getSpecies()); // 输出 "Human"

5.继承:通过extends关键字实现类之间的继承关系,并且子类可以使用super关键字调用父类的构造函数或其他方法

复制代码
class Employee extends Person {
  constructor(name, age, position) {
    super(name, age);
    this.position = position;
  }

  introduceYourself() {
    super.sayHello();
    console.log(`I work as a ${this.position}.`);
  }
}

6.getter 和 setter:类中可以定义访问器属性(getter/setter),用来控制对对象属性的读取和赋值操作

复制代码
class Person {
  constructor(name, age) {
    this._age = age;
  }

  get age() {
    return this._age;
  }

  set age(value) {
    if (value >= 0) {
      this._age = value;
    } else {
      console.error("Age cannot be negative.");
    }
  }
}
相关推荐
格林威1 分钟前
工业相机图像高速存储(C#版):内存映射文件方法,附Basler相机C#实战代码!
开发语言·人工智能·数码相机·c#·机器视觉·工业相机·堡盟相机
Nuopiane2 分钟前
MyPal3(3)
java·开发语言
lihihi5 分钟前
P1650 [ICPC 2004 Shanghai R] 田忌赛马(同洛谷2587)
开发语言·算法·r语言
阿蒙Amon7 分钟前
C#常用类库-详解Autofac
开发语言·c#
爱上妖精的尾巴7 分钟前
8-18 WPS JS宏 正则表达式-边界匹配
开发语言·javascript·正则表达式·wps·jsa
格林威7 分钟前
工业相机图像高速存储(C#版):内存映射文件方法,附堡盟相机C#实战代码!
开发语言·人工智能·数码相机·计算机视觉·c#·工业相机·堡盟相机
爱上妖精的尾巴7 分钟前
8-20 WPS JS宏 正则表达式-懒惰匹配
服务器·前端·javascript
波波0078 分钟前
每日一题:什么是强类型语言和弱类型语言?
开发语言
Ralph_Y8 分钟前
正则表达式
开发语言·c++·正则表达式
网络点点滴8 分钟前
组件通信props方式
前端·javascript·vue.js