JavaScript 类(class) 类是用于创建对象的模板。 我们使用 class 关键字来创建一个类,类体在一对大括号 {} 中,我们可以在大括号 {} 中定义类成员的位置,如方法或构造函数。 每个类中包含了一个特殊的方法 constructor(),它是类的构造函数,这种方法用于创建和初始化一个由 class 创建的对象。 创建一个类的语法格式如下: ``` class ClassName { constructor() { ... } } ``` ``` class abc { constructor(name, url) { this.name = name; this.url = url; } } ``` 以上实例创建了一个类,名为 "abc"。 类中初始化了两个属性: "name" 和 "url"。 浏览器支持 表格中的数字表示支持该属性的第一个浏览器版本号。 |Chrome 49|Edge 12|Firefox 45|Safari 9|Opera 36| |---| |Mar, 2016|Jul, 2015|Mar, 2016|Oct, 2015|Mar, 2016| ###使用类 定义好类后,我们就可以使用 **new **关键字来创建对象: ``` class classTest { constructor(name, url) { this.name = name; this.url = url; } } let site = new classTest("name", "https://cn.bing.com"); ``` 创建对象时会自动调用构造函数方法 constructor()。 类表达式 类表达式是定义类的另一种方法。类表达式可以命名或不命名。命名类表达式的名称是该类体的局部名称。 ``` // 未命名/匿名类 let classname = class { constructor(name, url) { this.name = name; this.url = url; } }; console.log(classname.name); // output: "classname" // 命名类 let classname = class abcd { constructor(name, url) { this.name = name; this.url = url; } }; console.log(classname.name); // 输出: "abcd" ``` 构造方法 构造方法是一种特殊的方法: 构造方法名为 constructor()。 构造方法在创建新对象时会自动执行。 构造方法用于初始化对象属性。 如果不定义构造方法,JavaScript 会自动添加一个空的构造方法。 类的方法 我们使用关键字 class 创建一个类,可以添加一个 constructor() 方法,然后添加任意数量的方法。 ``` class ClassName { constructor() { ... } method_1() { ... } method_2() { ... } method_3() { ... } } ``` 以下实例我们创建一个 "age" 方法,用于返回网站年龄: ``` <script> class abcd { constructor(name, year) { this.name = name; this.year = year; } age() { let date = new Date(); return date.getFullYear() - this.year; } } let abc = new abcd("教程", 2018); document.getElementById("demo").innerHTML = "教程 " + abc.age() + " 岁了。"; </script> ``` 我们还可以向类的方法发送参数: 实例 ``` class aaaa { constructor(name, year) { this.name = name; this.year = year; } age(x) { return x - this.year; } } let date = new Date(); let year = date.getFullYear(); let test = new aaa("aaa教程", 2020); document.getElementById("demo").innerHTML= "ddd教程 " + test.age(year) + " 岁了。"; ``` 严格模式 "use strict" 类声明和类表达式的主体都执行在严格模式下。比如,构造函数,静态方法,原型方法,getter 和 setter 都在严格模式下执行。 如果你没有遵循严格模式,则会出现错误: ``` class outobe { constructor(name, year) { this.name = name; this.year = year; } age() { // date = new Date(); // 错误 let date = new Date(); // 正确 return date.getFullYear() - this.year; } } ``` 参考 类方法 |方法|描述| |--| |constructor()|构造函数,用于创建和初始化类| 类关键字 |关键字|描述| |---- |extends|继承一个类| |static|在类中定义一个静态方法| |super|调用父类的构造方法|