JS 类简介

JavaScript 类

ECMAScript 2015,也称为 ES6,引入了 JavaScript 类。

JavaScript 类是 JavaScript 对象的模板。

JavaScript 类的语法

请使用关键字 class 创建一个类。

请始终添加一个名为 constructor() 的方法:

语法

class ClassName {  constructor() { ... }}

实例

class Car {  constructor(name, year) {    this.name = name;    this.year = year;  }}

上面的例子创建了一个名为 "Car" 的类。

该类有两个初始属性:"name" 和 "year"。

JavaScript 类不是对象。

它是 JavaScript 对象的模板

使用类

当您有了一个类时,可以使用该类来创建对象:

实例

let myCar1 = new Car("Ford", 2014);let myCar2 = new Car("Audi", 2019);

亲自试一试

上面的例子使用 Car 类来创建两个 Car 对象

在创建新对象时会自动调用构造方法(constructor method)。

构造方法

构造方法是一种特殊的方法:

  • 它必须有确切的名称的 “constructor”
  • 创建新对象时自动执行
  • 用于初始化对象属性
  • 如果您没有定义构造方法,JavaScript 会添加一个空的构造方法。

类方法

创建类方法的语法与对象方法相同。

请使用关键字 class 创建一个类。

请始终添加 constructor() 方法。

然后添加任意数量的方法。

语法

class ClassName {  constructor() { ... }  method_1() { ... }  method_2() { ... }  method_3() { ... }}

创建一个名为 "age" 的类方法,它返回车年:

实例

class Car {  constructor(name, year) {    this.name = name;    this.year = year;  }  age() {    let date = new Date();    return date.getFullYear() - this.year;  }}let myCar = new Car("Ford", 2014);document.getElementById("demo").innerHTML ="My car is " + myCar.age() + " years old.";

亲自试一试

您可以向类方法发送参数:

实例

class Car {  constructor(name, year) {    this.name = name;    this.year = year;  }  age(x) {    return x - this.year;  }}let date = new Date();let year = date.getFullYear();let myCar = new Car("Ford", 2014);document.getElementById("demo").innerHTML="My car is " + myCar.age(year) + " years old.";

亲自试一试

浏览器支持

下表注明首个完全支持 JavaScript 类的浏览器版本:

ChromeIEFirefoxSafariOpera
Chrome 49Edge 12Firefox 45Safari 9Opera 36
2016 年 3 月2015 年 7 月2016 年 3 月2015 年 10 月2016 年 3 月

"use strict"

类中的语法必须以“严格模式”编写。

如果您不遵循“严格模式”规则,将收到错误消息。

实例

在“严格模式”下,如果您使用变量而不声明它,会得到错误:

class Car {  constructor(name, year) {    this.name = name;    this.year = year;  }  age() {    // date = new Date();  // This will not work    let date = new Date(); // This will work    return date.getFullYear() - this.year;  }}

亲自试一试

JS 严格模式 中学习更多关于“严格模式”的内容。