三分钟让你搞懂Class类

类的基本知识

注:学习该部分知识内容的前置条件是搞懂原型链的知识哦!

例:

1)首先创建一个Person类,然后创建子类来继承他

js 复制代码
	//创建一个Person类
		class Person {	//构造器方法
			constructor(name,age){
				//构造器中的this是谁?------ 类的实例对象
				this.name = name
				this.age = age
			}
			//一般方法
			speak(){
				//speak方法放在了哪里?------类的原型对象上,供实例使用
				//通过Person实例调用speak时,speak中的this就是Person实例
				console.log(`我叫${this.name},我年龄是${this.age}`);
			}
		}
 const ldh=new Person('刘德华',18) //new 一个类的实例
console.log(ldh);
ldh.speak()

2)接下来我们创建一个子类并继承父类

继承方式一:子类不再添加新的内容

由于上面的父类的构造器中已经有了name,age,如果子类想完全继承父类,那么可以直接这么写:

js 复制代码
class Student extends Person{

}
const zhangsan=new Student('张三',102)
console.log(zhangsan)

我们会发现,子类会直接把父类中的构造器搬过来,且虽然原型上没有父类的speak方法,但是通过原型链继续往上找,同样可以使用父类身上是speak方法,这就是简单继承

继承方式二:子类需要添加新的内容

如果子类中需要添加新的内容,那么子类也需要写构造器来构造内容,此时要用到super来继承父类构造器中的内容;那如果子类中也想有一个speak方法,而且说的功能更多,那怎么办呢?

那就重写从父类继承过来的方法,这样Student的原型对象上就会有speak方法了,虽然父类上也有speak方法,但是当根据原型链查找的规则,找到Student身上的方法就不再查找了

js 复制代码
//创建一个Student类,继承于Person类
		class Student extends Person {
			constructor(name,age,grade){
				super(name,age)//继承父类的构造器中内容
				this.grade = grade
				this.school = '尚硅谷'
			}
			//重写从父类继承过来的方法
			speak(){
				console.log(`我叫${this.name},我年龄是${this.age},
                                我读的是${this.grade}年级`);
				this.study()
			}
			study(){
				//study方法放在了哪里?------类的原型对象上,供实例使用
				//通过Student实例调用study时,study中的this就是Student实例
				console.log('我很努力的学习');
			}
		}

注:

1.类中的构造器不是必须要写的,要对实例进行一些初始化的操作,如添加指定属性时才写。 2.如果A类继承了B类,且A类中写了构造器,那么A类构造器中的super是必须要调用的。 3.类中所定义的方法,都放在了类的原型对象上,供实例去使用。

相关推荐
不老刘2 分钟前
破局 EMR 痛点:如何化解“护理记录跨页”与“A4物理打印”的架构冲突
前端·架构
m0_738120727 分钟前
后渗透维权提权基础——CTF模拟红队进行权限维持(一)
服务器·前端·python·安全·web安全·php
朝阳398 分钟前
react【实战】自定义下拉框、单选、多选、输入框
前端·javascript·react.js
涵涵(互关)12 分钟前
GoView各项目文件中的相关语法3
前端·vue.js·typescript
李白的天不白12 分钟前
vs code -- uniapp gets
前端
lifewange21 分钟前
CNode API v1 完整接口文档(JSON 规范整理)
java·前端·json
QQ1__8115175159 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态9 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子9 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室9 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离