JavaScript 类(class)
JavaScript 类(class)
类是用于创建对象的模板。
我们使用 class 关键字来创建一个类,类体在一对大括号 {} 中,我们可以在大括号 {} 中定义类成员的位置,如方法或构造函数。
每个类中包含了一个特殊的方法 constructor(),它是类的构造函数,这种方法用于创建和初始化一个由 class 创建的对象。
创建一个类的语法格式如下:
实例:
实例
以上实例创建了一个类,名为 "Runoob"。
类中初始化了两个属性: "name" 和 "url"。
浏览器支持
表格中的数字表示支持该属性的第一个浏览器版本号。
Chrome 49 | Edge 12 | Firefox 45 | Safari 9 | Opera 36 |
Mar, 2016 | Jul, 2015 | Mar, 2016 | Oct, 2015 | Mar, 2016 |
使用类
定义好类后,我们就可以使用 new 关键字来创建对象:
实例
创建对象时会自动调用构造函数方法 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() 方法,然后添加任意数量的方法。
constructor() { ... }
method_1() { ... }
method_2() { ... }
method_3() { ... }
}
以下实例我们创建一个 "age" 方法,用于返回网站年龄:
实例
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() + " 岁了。";
我们还可以向类的方法发送参数:
实例
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 都在严格模式下执行。
如果你没有遵循严格模式,则会出现错误:
实例
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 | 调用父类的构造方法 |
最新文章
- Android 利用SharedPreferences保存与删除 用户登录数据
- 【poj 2185】Milking Grid(字符串--KMP+问题分解)
- git linux
- HDU 5024 Wang Xifeng&;#39;s Little Plot 搜索
- DRP过后,感受知识间的通性
- canvas学习笔记(一)
- frp内网 穿透映射使内网svn可外网访问
- (转)C#中的那些全局异常捕获
- CentOS7下安装JDK详细过程
- window.location.reload(false);window.location.reload(true);history.Go(0)区别
- socket套接字和驱动绑定分析
- perl ExtUtils::Manifest
- JS基础循环语句练习
- HDU 6034 贪心
- JavaScript --经典问题
- Wordcount -- MapReduce example -- Reducer
- ROC
- requestAnimationFrame 与 cancelAnimationFrame
- 数据校验(2)--demo1---bai
- angular之增删改查
热门文章
- App几个可能造成内存泄漏的情况:
- VUE Angular通用动态列表组件-亦可为自动轮播组件-01-根据数据量自动纵向滚动,鼠标划入停止滚动
- Hash table集合-练习_计算一个字符串中每个字符出现次数
- 穿透的switch语句-循环概述与基本组成部分
- 【教程搬运】分析并编写suricata规则(内含两个示例)
- 芯片下载相关-CH32系列芯片下载方式汇总及教程
- java的部分特性与下载安装
- window.alert和console.log()
- EPICS Archiver Appliance的定制部署2
- Struts2文件配置介绍