JavaScript 类(class)

简介: JavaScript 类(class)

类是用于创建对象的模板。

我们使用 class 关键字来创建一个类,类体在一对大括号 {} 中,我们可以在大括号 {} 中定义类成员的位置,如方法或构造函数。

每个类中包含了一个特殊的方法 constructor(),它是类的构造函数,这种方法用于创建和初始化一个由 class 创建的对象。

创建一个类的语法格式如下:

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

实例:

实例

class Runoob {  constructor(name, url) {    this.name = name;     this.url = url;   }}

以上实例创建了一个类,名为 "Runoob"。

类中初始化了两个属性: "name" 和 "url"。

浏览器支持

表格中的数字表示支持该属性的第一个浏览器版本号。

Chrome 49 Edge 12 Firefox 45 Safari 9 Opera 36
Mar, 2016 Jul, 2015 Mar, 2016 Oct, 2015 Mar, 2016

使用类

定义好类后,我们就可以使用 new 关键字来创建对象:

实例

class Runoob {  constructor(name, url) {    this.name = name;     this.url = url;   }} let site = new Runoob("菜鸟教程",  "https://www.runoob.com");


尝试一下 »

创建对象时会自动调用构造函数方法 constructor()

类表达式

类表达式是定义类的另一种方法。类表达式可以命名或不命名。命名类表达式的名称是该类体的局部名称。

实例

// 未命名/匿名类let Runoob = class {  constructor(name, url) {    this.name = name;     this.url = url;   }};console.log(Runoob.name);// output: "Runoob" // 命名类let Runoob = class Runoob2 {  constructor(name, url) {    this.name = name;     this.url = url;   }};console.log(Runoob.name);// 输出: "Runoob2"

构造方法

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

  • 构造方法名为 constructor()。
  • 构造方法在创建新对象时会自动执行。
  • 构造方法用于初始化对象属性。
  • 如果不定义构造方法,JavaScript 会自动添加一个空的构造方法。

类的方法

我们使用关键字 class 创建一个类,可以添加一个 constructor() 方法,然后添加任意数量的方法。

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

以下实例我们创建一个 "age" 方法,用于返回网站年龄:

实例

class Runoob {  constructor(name, year) {    this.name = name;     this.year = year;   }  age() {    let date = new Date();     return date.getFullYear() - this.year;   }} let runoob = new Runoob("菜鸟教程", 2018);document.getElementById("demo").innerHTML ="菜鸟教程 " + runoob.age() + " 岁了。";


尝试一下 »

我们还可以向类的方法发送参数:

实例

class Runoob {  constructor(name, year) {    this.name = name;     this.year = year;   }  age(x) {    return x - this.year;   }} let date = new Date();let year = date.getFullYear();  let runoob = new Runoob("菜鸟教程", 2020);document.getElementById("demo").innerHTML="菜鸟教程 " + runoob.age(year) + " 岁了。";


尝试一下 »

严格模式 "use strict"

类声明和类表达式的主体都执行在严格模式下。比如,构造函数,静态方法,原型方法,getter 和 setter 都在严格模式下执行。

如果你没有遵循严格模式,则会出现错误:

实例

class Runoob {  constructor(name, year) {    this.name = name;     this.year = year;   }  age() {    // date = new Date();  // 错误    let date = new Date(); // 正确    return date.getFullYear() - this.year;   }}


尝试一下 »

下图实例使用类未声明的变量:

更多严格模式可以参考:JavaScript 严格模式(use strict)


参考

类方法

方法 描述
constructor() 构造函数,用于创建和初始化类

类关键字

关键字 描述
extends 继承一个类
static 在类中定义一个静态方法
super 调用父类的构造方法
目录
相关文章
|
6天前
|
JavaScript 前端开发
js之class继承|27
js之class继承|27
|
5天前
|
JavaScript 前端开发 Java
JavaScript 类知识点概览
概览JavaScript中类的知识点,包括类的定义和实现、添加方法和get/set方法、类的继承和静态方法的使用。通过学生类和人员类的例子,演示了类的构造器、方法定义、继承关系和静态方法的调用。
JavaScript 类知识点概览
|
6天前
|
JavaScript 前端开发 开发者
JavaScript 类继承
JavaScript 类继承
10 1
|
8天前
|
JavaScript 安全
ES6中JS类实现的解读
ES6中JS类实现的解读
13 2
|
29天前
|
JavaScript 前端开发
JavaScript基础知识-构造函数(也称为"类")定义
本文介绍了JavaScript中构造函数(也称为“类”)的定义和使用方法。
26 1
JavaScript基础知识-构造函数(也称为"类")定义
|
13天前
|
JavaScript 前端开发 索引
|
21天前
|
JavaScript 前端开发
JS中Promise的类式实现写法
JS中Promise的类式实现写法
|
3天前
|
C++ Windows
HTML+JavaScript构建C++类代码一键转换MASM32代码平台
HTML+JavaScript构建C++类代码一键转换MASM32代码平台
|
2月前
|
JavaScript 前端开发
记录Javascript数组类练习
记录Javascript数组类练习
|
4月前
|
JavaScript 前端开发
JavaScript 中,可以使用类继承来创建子类
JavaScript 中,可以使用类继承来创建子类
26 0