TS中的类

news2024/9/22 19:45:50

目录

ES6的类

类的概念

类的构成

类的创建

声明

      构造函数

定义内容

创建实例

TS中的类

类声明

构造函数

属性和方法

实例化类

继承

访问修饰符

public

private

protected

成员访问修饰符的使用原则

访问器

只读成员与静态成员

readonly

static

修饰符总结


首先要理解ES6中的类

ES6的类

类的概念

在 ES6 中,类是引入的一种新的语言特性,用于实现面向对象编程的概念。类是一种模板,用于创建具有相同属性和方法的对象。可以使用 class 关键字声明一个类

类由类名、构造函数(constructor)和类方法(methods)组成。类名可以是任何有效的标识符,构造函数由 constructor 关键字和函数体组成,类方法可以包括任何有效的函数代码。

当创建对象实例时,构造函数会被自动调用。类方法可以通过对象实例来调用,

类具有以下特性:

  • 继承(Inheritance):子类可以继承父类的属性和方法。
  • 封装(Encapsulation):通过使用访问修饰符(public、private、protected)来限制对象属性的访问权限。
  • 多态(Polymorphism):同一类型的对象可以具有不同的表现形式。

ES6 中的类是基于原型链实现的,实质上仍然是以函数的形式存在,只是语法简洁了许多,更接近于其他 OOP 语言的实现方式,使得 JS 的面向对象编程更加直观和易于维护。

类的构成

一个类由以下几个组成部分构成:

1. 类名(Class Name):类名用于标识类的名称,通常采用首字母大写的驼峰命名规则。

2. 构造函数(Constructor):构造函数是类中的一种特殊方法,用于初始化对象的属性。构造函数使用 `constructor` 关键字定义,在创建类的实例时被自动调用。

3. 属性(Properties):类的属性用于描述类对象的状态。属性可以是类内部的数据,也可以是直接定义在类上的静态属性。在类中定义属性时,可以使用访问修饰符(public、private、protected)来限制属性的访问权限。

4. 方法(Methods):类的方法被用于定义对象的行为。方法定义在类的内部,可以通过类的实例来调用。方法可以是类的实例方法,也可以是类上的静态方法。

5. 继承(Inheritance):通过继承,一个类可以派生出子类,并从父类继承属性和方法。子类可以覆盖父类的方法或添加新的属性和方法。

6. 访问修饰符(Access Modifiers):访问修饰符用于控制类的成员的访问权限。ES6 提供了三种访问修饰符:public、private 和 protected。public 表示公开的,可以在类的内部和外部访问;private 表示私有的,只能在类的内部访问;protected 表示受保护的,可以在类的内部和派生类中访问。

类是面向对象编程的核心概念,它提供了一种结构化的方式来组织代码,并且使代码更具可维护性和可扩展性。

类的创建

在 ES6 中,创建一个类的基本语法是使用 class 关键字,然后定义类名和类的内容。以下是创建类的一般步骤:

声明

        使用 class 关键字声明一个类,并给类取一个合适的名称:

class ClassName {
  // 类的内容
}

      构造函数

 在类的内部定义构造函数(constructor):构造函数用于初始化对象的属性,在创建类的实例时自动调用。构造函数使用 constructor 关键字声明,可以接受参数用于初始化属性:

class ClassName {
  constructor(param1, param2) {
    // 构造函数的代码
    this.property1 = param1;
    this.property2 = param2;
  }
}

定义内容

在类的内部定义其他方法:除了构造函数外,你可以在类的内部定义其他方法,用于描述对象的行为。方法的定义与普通函数类似,不过不需要使用 function 关键字:

class ClassName {
  constructor(param1, param2) {
    // 构造函数的代码
    this.property1 = param1;
    this.property2 = param2;
  }
  
  method1() {
    // 方法代码
  }
  
  method2() {
    // 方法代码
  }
}

创建实例

使用 new 关键字创建类的实例:通过 new 关键字后跟类名,可以创建类的一个实例:

const instance = new ClassName(param1, param2);

这样就创建了一个类的实例,可以使用实例对象来调用类的方法和访问属性。

以上是创建一个简单的类的步骤,你可以根据需要在类中添加更多的属性和方法。同时还可以使用继承等特性来进行功能的扩展。

TS中的类

在 TypeScript 中,类(Class)是面向对象编程的基本概念之一,用于创建对象并定义对象的属性和方法。它提供了一种结构化的方式来组织代码和数据,并支持面向对象的特性,如继承、封装和多态。

类声明

使用 class 关键字声明一个类,并给类取一个合适的名称。

class ClassName {
  // 类的内容
}

构造函数

类可以定义一个特殊的方法叫做构造函数(constructor),用于初始化对象的属性。构造函数在创建类的实例时自动调用,并且可以接受参数用于初始化属性。

class ClassName {
  constructor(param1: Type, param2: Type) {
    // 构造函数的代码
    this.property1 = param1;
    this.property2 = param2;
  }
}

属性和方法

类可以定义属性和方法来描述对象的属性和行为。属性可以存储数据,而方法定义了对象可以执行的操作。属性和方法的声明语法与 JavaScript 类似。

class Person {
  // 声明  属性
  name:string;
  age:number;
  // 通过构造函数对属性进行初始化
  constructor(name:string, age:number) {
    this.name = name;  //this指的是当前person实例
    this.age = age;
  }
  showName() {
    console.log(this.name);
  }
  showAge() {
    console.log(this.age)
  }
}

let p = new Person('zs', 20);
p.showName();

实例化类

通过 new 关键字后跟类名,可以创建类的一个实例。实例化类时,会自动调用构造函数。

const instance = new ClassName(value1, value2);

继承

类支持继承机制,子类可以继承父类的属性和方法,并可以添加自己的属性和方法。使用 extends 关键字实现继承关系。

super关键字

  • super 关键字用于访问和调用对象父类上的函数。可以调用父类的构造函数,也可以调用父类的普通函数

子类的特有属性在super后

class Person { // 父类
    uname:string;
    constructor(uname:string){
        this.uname = uname;
    } 
}
class Student extends Person { // 子类继承父类
    age:number;
    constructor(uname:string,age:number){
        super(uname); // 调用父类的constructor(uname)
        this.age = age; // 定义子类独有的属性
    } 
}

访问修饰符

在 TypeScript 中,访问修饰符是用于限制类成员(属性和方法)访问权限的关键字。它们可以控制外部代码对类成员的访问级别,提供了封装和信息隐藏的特性。TypeScript 提供了三种访问修饰符:public、private 和 protected。

默认情况下,类成员是 public 的(可以被任何地方访问)。

private 成员只能在类内部访问

protected 成员可以在类及其子类中访问。

public

默认的访问修饰符,即使不显式指定访问修饰符,类成员也会被认定为 public。public 成员可以在类内部、子类和类的外部被访问。

class Person {
  // 属性
  public name:string;
  // age也是公有属性,没加public默认就是public  
  age:number;
  // 通过构造函数对属性进行初始化
  constructor(name:string, age:number) {
    this.name = name;
    this.age = age;
  }
  showName() {
    console.log(this.name);
  }
  showAge() {
    console.log(this.age)
  }
}

let p = new Person('zs', 20);
console.log(p.name) // zs
p.name = 'lisi';
console.log(p.name) // lisi
private

private 访问修饰符用于限制成员只能在类内部访问,无法在类的外部或子类中进行访问。

class Person {
  // 属性
  private age:number = 20;
  showAge() {
    console.log(this.age)
  }
}

let p = new Person();
console.log(p.age) // error: Property 'age' is private and only accessible within class 'Person'
protected

protected 访问修饰符限制成员可以在类内部和子类中访问,但不能在类的外部进行访问。

成员访问修饰符的使用原则
  • 最小化原则,能用private的绝对不用public和protected
  • 我们最好把所有的属性都设置为私有属性,方法可以是公有的
  • 如果确实需要在类的外部访问类内部的属性,那么我们也是以方法的形式访问我们类内部的属性,而不是直接访问

访问器

在ts中为我们提供了访问器,可以使我们更加方便的访问类内部的属性

class Person {
    private _name:string;
    age:number;
    constructor(name:string,age:number){
        this._name = name; //this指的是当前person实例
        this.age = age //给name和age属性赋值,赋值前要先声明
    }
    showName(){
        console.log(this._name);

    }
    get name(){  //通过get访问器来获取name的值
        return this._name
    }
    set name(value:string){  //通过set访问器来获取name的值
         this._name = value
    }

}

const y = new Person('uu',80)
console.log(y.name);   // =>'uu'
y.name='ww'
console.log(y.name); // =>'ww'
y.showName()  // =>'ww'

只读成员与静态成员

  • 只读成员:在类的成员前面加上readonly,那么这个成员就属于只读成员
  • 静态成员:在类的成员前面加上static,那么这个成员就属于静态成员。静态成员只有类才可以访问。
  • 实例成员:实例成员就是只有类的实例才能够访问的成员
readonly

只能在声明属性的时候进行赋值,或者在constructor构造函数中进行赋值

// 有什么用----设计图纸
class Person {
  readonly name:string; // 静态成员
  // 构造函数
  constructor(name:string) {
    this.name = name;
  }
  // 方法(函数)
  showName() {
    // 在函数中要项访问属性的话,必须在属性前面加上this
    console.log(this.name)
  }
}

// 把类进行实例化
let p = new Person('zs')

console.log(p.name)
static

静态成员

class Person {
        readonly name:string;  //只读,在类内部也不能修改
        age:number; 
        static height :number //静态成员,只能在类内部访问属性和方法,实例不可以
        constructor(name:string,age:number,height:number){
            this.name = name; 
            this.age = age 
            Person.height=height  //静态成员
        }
        showName(){
            console.log(this.name);
            
        }   
    }
    const p = new Person('aa',20,180)
    console.log(Person.height);
   

如果使用this访问,会出现以下提示 

修饰符总结
  • 只读修改符readonly和静态修饰符static可以混用,但是必须是先是static再是readonly
  • 成员修饰符(public、private、protected)和只读修饰符readonly、静态修饰符static混用,必须是成员修饰符在前,只读修饰符和静态修饰符在后
  • 成员修饰符之间不能用混用

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1369311.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL之导入导出远程备份

目录 一. navicat导入导出 二. mysqldump命令导入导出 导入 导出 三. load data infile命令导入导出 导入 导出 四. 远程备份 导入 导出 思维导图 一. navicat导入导出 导入:右键➡运行SQL文件 导出:选中要导出的表➡右键➡转储SQL文件➡数据和结…

【PB续命07】JDBC连接达梦数据库

JDBC(Java DataBase Connectivity) 称为Java数据库连接,它是一种用于数据库访问的应用程序API,由一组用Java语言编写的类和接口组成,有了JDBC就可以用同一的语法对多种关系数据库进行访问,而不用担心其数据库操作语言的差异。 有了…

基于Python的货币识别技术实现

目录 介绍本文的目的和意义货币识别技术的应用场景 货币识别的基本原理图像处理技术在货币识别中的应用特征提取方法:SIFT、HOG等支持向量机(SVM)分类器的使用 实现过程数据集的收集和预处理特征提取和训练分类器 参考文献 介绍 本文的目的和…

Spring事务控制见解6

7.Spring事务控制 7.1.事务介绍 7.1.1.什么是事务? 当你需要一次执行多条SQL语句时,可以使用事务。通俗一点说,如果这几条SQL语句全部执行成功,则才对数据库进行一次更新,如果有一条SQL语句执行失败,则这…

软件测试|Chrome 115之后的版本,如何更新driver?

问题描述 前两天在运行一个web自动化测试脚本时,报了如下的错误,This version of ChromeDriver only supports Chrome version 113 Current browser version is 115.0.5790.110 with binary,如下图所示: 该报错提示我&#xff0c…

灵魂三连问:是5G卡吗?支持5G吗?是5G套餐吗

关于5G的问题,小伙伴们的疑问是不是很多,它和4G到底有什么区别呢?什么是5G卡?什么是5G套餐?支持5G吗?什么是5G基站?我想大家现在一定是晕的,下面小编来给大家解惑! 1&…

C语言入门教程,C语言学习教程(第二部分:C语言初探)一

第二部分:C语言初探 本章主要讲解C语言编程环境的搭建,让大家能够编写并运行C语言代码,其中,编译器是重点讲解内容。 本章还对一段简单的C语言代码进行了分析,让大家明白了C语言程序的基本结构。 一、第一个C语言程序…

【教学类-45-03】X-Y之间的“三连加减“题(a+b-c=)

作品展示: 背景需求: 【教学类-45-02】X-Y之间的“三连减“题(a-b-c)-CSDN博客文章浏览阅读465次,点赞15次,收藏7次。【教学类-45-02】X-Y之间的"三连减"题(a-b-c)https://blog.csdn.net/reasonsummer/article/details…

前端实现搜索功能

最近遇到一个需求,用户在输入框输入关键字之后,点击搜索按钮后进行搜索,如下图,选中的数据在下面,上面展现的是搜索后的数据,现在选中了2条数据: 当用户输入KET后点击搜索,搜出的结果有16条,勾选全选选中后,将选中的16条的数据加到之前已选的2条数据里,于是此时已选…

JavaScript版数据结构与算法(一)栈、队列、链表、集合、树

一、前言 为什么要学习数据结构与算法?最重要的就是面试要考算法,另外就是如果在实际工作当中,能够使用算法优化代码,会提升代码质量和运行效率,作为一名前端人员可能在实际中用的并不是特别多。数据结构与算法是分不…

如何使用内网穿透实现iStoreOS软路由公网远程访问局域网电脑桌面

文章目录 简介一、配置远程桌面公网地址二、家中使用永久固定地址 访问公司电脑**具体操作方法是:** 简介 软路由是PC的硬件加上路由系统来实现路由器的功能,也可以说是使用软件达成路由功能的路由器。 使用软路由控制局域网内计算机的好处&#xff1a…

文心一言 VS 讯飞星火 VS chatgpt (175)-- 算法导论13.3 4题

四、用go语言,Teach 教授担心 RB-INSERT-FIXUP可能将 T.nil.color 设为 RED,这时,当 z 为根时第1行的测试就不会让循环终止。通过讨论 RB-INSERT-FIXUP永远不会将 T.nil.color 设置为 RED,来说明这位教授的担心是没有必要的。 文…

正则表达式Regex

是什么:一句话,正则表达式是对字符串执行模式匹配的技术。 从一段字符串中提取出所有英文单词、数字、字母和数字。 如果采用传统方法:将字符串的所有字符分割成单个,根据ASCII码判断,在一定范围内就是字母&#xff…

时序预测 | Matlab基于灰色隐马尔可夫模型(HMMP-GM11)的时间序列预测

时序预测 | Matlab基于灰色隐马尔可夫模型(HMMP-GM11)的时间序列预测 目录 时序预测 | Matlab基于灰色隐马尔可夫模型(HMMP-GM11)的时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 灰色HMMP-GM11改进模型,通过引入隐马尔可夫模型(HMM)来对原始数据进行状态分…

【2023最新版】20款经济高效的开源网络安全工具推荐

如果企业还没有试用过开源工具来满足日常网络安全需求,就意味着企业可能错过了很多免费的“午餐”。需要了解的是,现在很多开源安全工具都来自活跃的知名社区,技术先进且完全可信,并且有很多专业安全公司和大型运营商都参与其中。…

干货!数字化时代下的企业合规与增长

本文提炼总结自专刊《上市公司如何打好合规与增长的双赢之战》。全书40页,出品方纷享销客市场部。如有需要,请阅读原版电子书:上市公司如何打好合规与增长的双赢之战 目 录 一、潮起:一场复杂的博弈 1. 数字经济大潮对企业提…

适合邮件推广的行业有哪些?

邮件推广因其价格便宜覆盖范围广等优势备受各个行业的企业和单位欢迎,能有效的吸引潜在客户、增加销售额、提高品牌知名度。U-Mail邮件群发平台(根据已有客户给大家总结一下适合进行邮件推广的行业 一、电子电商行业 随着电子商务的普及,越来越多的消费…

xss-labs(6-9)

level6:欢迎来到level6 老规矩还是先看看输入框的闭合情况 尝试事件函数绕过 test" onclick="alert(欢迎来钓鱼) 既然事件函数被转义了,那就使用我们第二关用过的绕过方法插入标签看看 test"><script>alert(欢迎来钓鱼)</script>// <

什么是博若莱新酒节?

在红酒圈儿里混&#xff0c;一定不能不知道博若莱新酒节&#xff0c;这是法国举世闻名的以酒为主题的重要节日之一。现已成为世界范围内庆祝当年葡萄收获和酿制的节日&#xff0c;被称为一年一度的酒迷盛会。 云仓酒庄的品牌雷盛红酒LEESON分享博若莱位于法国勃艮第南部&#x…

78.乐理基础-非常见拍号如何打拍子

内容来源于&#xff1a;三分钟音乐社 上一个内容&#xff1a;76.乐理基础-打拍子-二连音、四连音-CSDN博客 非常见的拍子就是下图中除了红圈里的五个拍号的拍号 最大优先级的规则&#xff1a; 规则一&#xff1a;所有的拍号绝对&#xff0c;永远都可以以一拍为单位&#xff0…