IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> TS定义class类 及类之间继承方法 -> 正文阅读

[JavaScript知识库]TS定义class类 及类之间继承方法

ES5的话 类主要靠的是构造函数原型链 这个就不多说了 感兴趣的朋友可以去看一下 但构造函数和原型链的用法 我老实说 他开始展现出被一些更规范语法取代的意向

ts定义一个基础类通过一个class的关键字
代码如下

class min{
  name:String;
  constructor(){
    this.name = '你好';
    console.log(this.name);
  }
}
let mint = new min();

运行效果就是 打印出了 ( 你好 ) 两个字
这里class 后的min是类的名字 这个大家可以随便起名
最上面的name是定义在类中的属性 constructor是类的构造函数
当这个类被实例化是 构造函数会自动执行
通常用来给类中的属性赋值

TS类中还可以定义函数 我们来看个有点多的代码

class min{
  name:String;
  age:Number;
  constructor(name:String, age:Number){
    this.name = name;
    this.age = age;
  }
  getName():String {
    return this.name
  }
  getAge():Number {
    return this.age
  }
  setAge(age):void {
    this.age = age
  }
  setName(name):void {
    this.name = name
  }
}
let mint = new min('裴元吉', 22);
console.log(mint.getAge())
console.log(mint.getName())
mint.setAge(50)
console.log(mint.getAge())
mint.setName('黄忠')
console.log(mint.getName())

这个代码相对就有点多了 确实也简单 我们在类中定义了两个属性
name:String 字符串类型的属性name
age:Number 数字类型的属性age
类的构造函数接收两个参数 然后在构造函数中给类自己的两个属性赋值
分别定义类他们的get和set方法
然后用一个mint 属性接收实例化min类 注意 实例化类就相当于调用了他的构造函数 就也要传递构造函数需要的参数
这里我们的打印效果如下
在这里插入图片描述

其次就是类的继承 这里我们就用上面的代码小改一下


class min{
  name:String;
  age:Number;
  con:String;
  constructor(name:String, age:Number){
    this.name = name;
    this.age = age;
  }
  getName():String {
    return this.name
  }
  getAge():Number {
    return this.age
  }
  setAge(age):void {
    this.age = age
  }
  setName(name):void {
    this.name = name
  }
}
class kowd extends min{
  con:String;
  constructor(name:String, age:Number,con:String){
     super(name,age)
     this.con = con;
     console.log(con);
  }
}
let mint = new kowd('裴元吉', 22, '我是新来的');
console.log(mint.getAge())
console.log(mint.getName())
mint.setAge(50)
console.log(mint.getAge())
mint.setName('黄忠')
console.log(mint.getName())

这里大家可以发现唯一不同的地方在于这个kowd
这里我们声明了一个kowd类 他通过关键字extends继承了我们之前声明的类min
其他的没什么 但继承了父类那在工造函数中一定要调用super 并在这个函数中传递父类构造函数中需要的参数 否则就会报错

然后在子类中可以拿到父类的属性和函数
这段代码的输出效果如下
在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-10 11:48:02  更:2022-05-10 11:51:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 20:14:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码