JS类之JavaScript类
声明
该文部分代码和内容节选自菜鸟教程,仅用作个人学习,特此声明
27、JS类
27.1 类的创建和使用
类是用于创建对象的模板。我们使用 class 关键字来创建一个类,类体在一对大括号 {} 中,我们可以在大括号 {} 中定义类成员的位置,如方法或构造函数。
每个类中包含了一个特殊的方法 constructor(),它是类的构造函数,这种方法用于创建和初始化一个由 class 创建的对象。
创建一个类的语法格式如下:
class ClassName { constructor() { ... } }
定义好类后,我们就可以使用 new 关键字来创建对象,创建对象时会自动调用构造函数方法 constructor()。
1、类的创建和使用练习
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JS类的创建</title>
</head>
<body>
<h2>JavaScript 类</h2>
<p>JavaScript类的使用</p>
<p id="demo" style="color:red;font-weight:bold"></p>
<script>
class Runoob {
constructor(name,url){
this.name = name;
this.url = url;
}
}
let site = new Runoob("菜鸟教程","www.runoob.com");
document.getElementById("demo").innerHTML =
site.name + " : " + site.url;
</script>
</body>
</html>
生成页面效果
2、类表达式
类表达式是定义类的另一种方法。类表达式可以命名或不命名。命名类表达式的名称是该类体的局部名称。未命名类表达式的名称将会被自动赋值为变量名
只是说有点难理解,看一个例子就懂了
// 未命名/匿名类 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 会自动添加一个空的构造方法。
27.2 类的方法
- 我们使用关键字 class 创建一个类,可以添加一个 constructor() 方法,然后添加任意数量的方法
- 可以向类的方法发送参数
- 类声明和类表达式的主体都执行在严格模式下。比如,构造函数,静态方法,原型方法,getter 和 setter 都在严格模式下执行。如果没有遵循严格模式,则会出现错误
练习一:类的方法添加
练习代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>类方法添加练习</title>
</head>
<body>
<h2>JavaScript 类的方法添加练习</h2>
<p>此实例展示了向Runoob类添加一个age()方法</p>
<p id="demo"></p>
<script>
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() + " 岁了。";
</script>
</body>
</html>
生成页面效果
练习二:向方法传递参数
练习代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>传递参数练习</title>
</head>
<body>
<h2>JavaScript 类的方法参数传递练习</h2>
<p>传递参数到 "age()" 方法。</p>
<p id="demo"></p>
<script>
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) + " 岁了。";
</script>
</body>
</html>
生成页面效果
练习三:严格模式下不能使用未声明变量
练习代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>严格模式验证练习</title>
</head>
<body>
<h2>JavaScript 类必须遵循严格模式 "strict mode" 的规则 </h2>
<p>JavaScript 类不能使用没有声明的变量。</p>
<p id="demo"></p>
<script>
class Runoob {
constructor(name, year) {
this.name = name;
this.year = year;
}
age() {
// date = new Date(); // 错误
let date = new Date(); // 正确
return date.getFullYear() - this.year;
}
}
myCar = new Runoob("菜鸟教程", 2020);
document.getElementById("demo").innerHTML =
"菜鸟教程 " + myCar.age() + " 岁了。";
</script>
</body>
</html>
如果在上边的实例中使用了未声明的变量date,即date = new Date();
,就会出现以下错误
分类:
JavaScript 入门随笔
, Day45
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律