您当前的位置:首页 > 电脑百科 > 程序开发 > 前端

一份不可多得的 TypeScript 学习笔记

时间:2022-02-21 12:27:19  来源:  作者:前端人

Hi,我是前端人,今日与君共勉!本篇文章主要介绍 typeScript 中类的定义、类的继承、类中成员修饰符等内容。


typeScript 中的类与 ES6 中的类非常相似,如果不知道 ES6 中的类,建议先学习下 ES6 中的 class 。本篇文章重点介绍 typeScript 中的类定义、继承以及修饰符。

1、类的定义

类描述了所创建的对象共同的属性和方法。typeScript 支持面向对象的所有特性,比如类、接口等。

在 typeScript 中定义类的时候,使用 class 关键字,类名首字母使用大写,类可以包含以下三个模块:

  • 字段 - 字段是类里面声明的变量,表示与对象有关的属性。
  • 构造函数 - 类实例化时自动调用,可以为实例化的对象分配内存
  • 方法 - 方法为对象要执行的某种操作。

定义属性的时候,需要添加属性类型,构造函数中的参数也需要加类型,引用任何一个类的成员的时候都用 this ,this 关键字表示当前类实例化的对象。使用 new 关键字来实例化对象,并初始化它。如示例:

class Web{
 workTime: string
 constructor(n:string) {
  this.workTime = n
 }
 showWork(){
  return "搬砖的前端"
 }
}
let qq = new Web("五年")
console.log(qq.showWork());
console.log(qq.workTime);

编译以上代码,得到的 js 代码如下:

"use strict";
class Web {
 constructor(n) {
  this.workTime = n;
 }
 showWork() {
  return "搬砖的前端";
 }
}
let qq = new Web("五年");
console.log(qq.showWork());
console.log(qq.workTime);

2、类的继承

typeScript 支持继承类,即可以在创建类的时候继承一个已存在的类,类继承的时候使用 extends 关键字,基于类的程序设计中一种最基本的模式是允许使用继承来扩展现有的类。比如:

class Dirnks{
 name: string
 constructor(n: string) {
  this.name = n
 }
 save(m: string) {
  console.log(`${this.name}饮料应该${m}`);
 }
}
class Soda extends Dirnks{
 constructor(n: string) {
  super(n)
 }
}
let kele = new Soda("可乐")
kele.save("冷藏")

上述示例是一个最基本的类继承,其中 Soda 继承了 Dirnks 的属性和方法,其中 Soda 是一个派生类,也叫做子类,Dirnks 是一个基类,也叫超类或父类。

派生类包含了一个构造函数,构造函数必须调用 super() ,会执行基类的构造函数。需要注意的是:在子类构造函数里访问 this 的属性之前,一定要先调用 super ,这是 typeScript 强制执行的一条重要规则。

如果父类和子类都包含某一方法时,方法名相同,但是具体执行内容不同的时候,该执行哪一个方法呢?

修改上述实例,给子类也添加一个方法,代码如下:

class Dirnks{
 name: string
 constructor(n: string) {
  this.name = n
 }
 save(m: string) {
  console.log(`${this.name}饮料应该${m}`);
 }
}
class Soda extends Dirnks{
 constructor(n: string) {
  super(n)
 }
 save() {
  return "存储方法"
 }
}
let kele = new Soda("可乐")
console.log(kele.save());

编译以上代码啊,得到的 js 代码如下:

"use strict";
class Dirnks {
 constructor(n) {
  this.name = n;
 }
 save(m) {
  console.log(`${this.name}饮料应该${m}`);
 }
}
class Soda extends Dirnks {
 constructor(n) {
  super(n);
 }
 save() {
  return "存储方法";
 }
}
let kele = new Soda("可乐");
console.log(kele.save());

此时会执行子类中的方法。其原理是,类继承后,子类可以对父类的方法进行重新定义,这个过程称之为方法的重写。

typeScript 中子类只能继承一个父类,虽然不支持继承多个类,但是支持多重继承。如下:

class One{
 name: string
 constructor(n: string) {
  this.name = n
 }
 show() {
  return "展示"
 }
}
class Two extends One{
 constructor(n:string) {
  super(n)
 }
}
class Three extends Two{
 constructor(n: string) {
  super(n)
 }
}
let three = new Three("剁成")
console.log(three.show());

3、修饰符

在 typeScript 中,可以使用访问控制符来保护对类、变量、方法和构造函数的访问。typeScript 支持 3 种不同的访问权限,分别为:

  • public(默认) - 公有,表示共享的属性和方法。可以在任何地方被访问。
  • protected - 受保护,表示属性和方法被保护,可以被自身以及子类访问,不能在类外面使用。
  • private - 私有,只能被其定义所在的类访问。
  • readonly - 只读,只读属性必须在声明时或构造函数里初始化。

理解 public

在上边类中的成员定义的时候,没有明确使用任何修饰符,默认的就是 public ,所以可以将上面的类改写为:

class HH{
 public name: string
 public constructor(n: string) {
  this.name = n
 }
}
let h = new HH("HH")
console.log(h.name);

使用 public 之后,对上面的应用并没有任何影响。

它的特点:被它标记的成员在类的里面、子类里面、类外面都可以访问到。

理解 protected

类中添加 protected 修饰符来修饰成员时,将上述实例的 public 修饰符修改为 protected 如下:

class HH{
 protected name: string
 constructor(n: string) {
  this.name = n
 }
}
let h = new HH("HH")
console.log(h.name); // 此处报错,提示 属性"name"受保护,只能在类 HH 及子类中访问

它的特点:被它标记的成员在类的里面、子类里面能使用,但是在类的外面不能使用。

理解 private

class HH{
 private name: string
 constructor(n: string) {
  this.name = n
 }
}
class H extends HH{
 constructor(n: string) {
  super(n)
 }
 show() {
  console.log(this.name); // 报错
 }
}
let h = new H("HH")
console.log(h.name);  // 报错
h.show()

上面的示例报错,提示:属性“name”为私有属性,只能在类“HH”中访问。

它的特点:被它标记的成员不能再声明它的类的外部访问。



Tags:TypeScript   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
一文读懂 TypeScript 泛型及应用
泛型是静态类型语言的基本特征,允许将类型作为参数传递给另一个类型、函数、或者其他结构。TypeScript 支持泛型作为将类型安全引入组件的一种方式。这些组件接受参数和返回...【详细内容】
2023-11-20  Search: TypeScript  点击:(196)  评论:(0)  加入收藏
TypeScript 5.3 来了,一大波新特性
根据 TypeScript 路线图,TypeScript 5.3 计划于 11 月 14 日发布。下面是该版本带来的新特性: 导入属性 导入类型中稳定支持 resolution-mode 所有模块模式均支持 resolution-...【详细内容】
2023-11-16  Search: TypeScript  点击:(163)  评论:(0)  加入收藏
万字详解 TypeScript 高级用法
TypeScript 是一种类型安全的 JavaScript 超集,除了基本类型和对象类型之外,TypeScript 还提供了一些高级类型系统,使得我们可以更好地处理复杂的数据结构和业务逻辑。本文将深...【详细内容】
2023-10-31  Search: TypeScript  点击:(340)  评论:(0)  加入收藏
TypeScript 不是一种编程语言?
【CSDN 编者按】Type 算是一种编程语言吗?来看看你是否真的了解Type 和 Java 的区别以及它的使用场景。‍‍‍‍‍‍‍‍‍‍‍‍‍...【详细内容】
2023-09-15  Search: TypeScript  点击:(221)  评论:(0)  加入收藏
TypeScript 出现 Go 和 Rust的 错误? 没有Try/Catch?
JavaScript 依靠抛出异常来处理错误,而 Go 和 Rust 将它们视为值。 你可能认为这没什么大不了的……但是,孩子,这可能听起来微不足道; 然而,它改变了游戏规则。那么,...【详细内容】
2023-09-07  Search: TypeScript  点击:(225)  评论:(0)  加入收藏
TypeScript 5.3 初探,有你想要的功能吗?
【CSDN 编者按】本文所提到的这些功能,你最希望哪个能实现。原文链接:https://www.totaltype.com/type-5-3作者 | Matt Pocock 翻译 | ChatGPT责编 | 梦依丹出品 | CSDN(ID:CSDN...【详细内容】
2023-08-30  Search: TypeScript  点击:(322)  评论:(0)  加入收藏
TypeScript 程序员晋级的 11 个必备技巧
当你学习TypeScript时,你的第一印象可能会欺骗你:这不就是JavaScript注解的一种方式吗?不就是编译器用来帮助我找到潜在bug的吗?虽然这种说法没错,但随着你对TypeScript不断了解...【详细内容】
2023-04-21  Search: TypeScript  点击:(237)  评论:(0)  加入收藏
深入理解 TypeScript 高级用法
TypeScript 是一种类型安全的 JavaScript 超集,除了基本类型和对象类型之外,TypeScript 还提供了一些高级类型系统,使得我们可以更好地处理复杂的数据结构和业务逻辑。本文将深...【详细内容】
2023-03-28  Search: TypeScript  点击:(209)  评论:(0)  加入收藏
字节 React + TypeScript 实践总结篇
❗️ 准备知识 熟悉 React 熟悉 TypeScript (参考书籍:2ality's guide[1], 初学者建议阅读:chibicode's tutorial[2]) 熟读 React 官方文档 TS 部分[3] 熟读 TypeScript...【详细内容】
2023-01-29  Search: TypeScript  点击:(245)  评论:(0)  加入收藏
JavaScript 和 Typescript 中的 Promise
厌倦了理清 JavaScript 或 TypeScript 项目中的异步代码?您是否希望有一种方法可以使您的异步进程像运转良好的机器一样运行? 如果是这种情况,我们为您提供了一个解决方案:promi...【详细内容】
2023-01-09  Search: TypeScript  点击:(297)  评论:(0)  加入收藏
▌简易百科推荐
20k级别前端是怎么使用LocalStorage的,想知道吗?
当咱们把咱们想缓存的东西,存在localStorage、sessionStorage中,在开发过程中,确实有利于咱们的开发,咱们想看的时候也是一目了然,点击Application就可以看到。前言大家好,我是林...【详细内容】
2024-03-26  前端之神  微信公众号  Tags:前端   点击:(13)  评论:(0)  加入收藏
前端不存在了?盲测64%的人更喜欢GPT-4V的设计,杨笛一等团队新作
3 月 9 日央视的一档节目上,百度创始人、董事长兼 CEO 李彦宏指出,以后不会存在「程序员」这种职业了,因为只要会说话,人人都会具备程序员的能力。「未来的编程语言只会剩下两种...【详细内容】
2024-03-11  机器之心Pro    Tags:前端   点击:(16)  评论:(0)  加入收藏
前端开始“锈化”?Vue团队开源JS打包工具:基于Rust、速度极快、尤雨溪主导
Vue 团队已正式开源Rolldown —— 基于 Rust 的 JavaScrip 打包工具。Rolldown 是使用 Rust 开发的 Rollup 替代品,它提供与 Rollup 兼容的应用程序接口和插件接口...【详细内容】
2024-03-09  OSC开源社区    Tags:Vue   点击:(20)  评论:(0)  加入收藏
两年前端经验还不会手写Promise?
什么是promise?当我们处理异步操作时,我们经常需要进行一系列的操作,如请求数据、处理数据、渲染UI等。在过去,这些操作通常通过回调函数来处理,但是回调函数嵌套过多会导致代码...【详细内容】
2024-03-07  海燕技术栈  微信公众号  Tags:Promise   点击:(27)  评论:(0)  加入收藏
网站开发中的前端和后端开发有什么区别
前端开发和后端开发都是干什么的?有哪些区别?通俗地讲,前端干的工作是用户可以直接看得见的,而后端开发的工作主要在服务端,用户不太能直接看到。虽然前端开发和后端开发的工作有...【详细内容】
2024-02-21  CarryData    Tags:前端   点击:(35)  评论:(0)  加入收藏
网站程序开发中的前后端分离技术
随着互联网的快速发展和技术的不断创新,传统的网站开发模式已经难以满足日益增长的业务需求。为了提高开发效率、增强系统的可维护性和可扩展性,前后端分离技术逐渐成为了网站...【详细内容】
2024-01-31  网站建设派迪星航    Tags:前后端分离   点击:(26)  评论:(0)  加入收藏
如何优雅的实现前端国际化?
JavaScript 中每个常见问题都有许多成熟的解决方案。当然,国际化 (i18n) 也不例外,有很多成熟的 JavaScript i18n 库可供选择,下面就来分享一些热门的前端国际化库!i18nexti18ne...【详细内容】
2024-01-17  前端充电宝  微信公众号  Tags:前端   点击:(76)  评论:(0)  加入收藏
Vue中Scope是怎么做样式隔离的?
scope样式隔离在 Vue 中,样式隔离是通过 scoped 特性实现的。当在一个组件的 <style> 标签上添加 scoped 特性时,Vue 会自动为这个样式块中的所有选择器添加一个唯一的属性,以...【详细内容】
2024-01-04  海燕技术栈  微信公众号  Tags:Vue   点击:(83)  评论:(0)  加入收藏
vue3中 ref和 reactive的区别 ?
最近有朋友在面试过程中经常被问到这么一个问题,vue3 中的ref 和 reactive的区别在哪里,为什么 要定义两个API 一个 api不能实现 响应式更新吗??带着这个疑问 ,我们 接下来进行逐...【详细内容】
2024-01-03  互联网高级架构师  今日头条  Tags:vue3   点击:(42)  评论:(0)  加入收藏
React18 与 Vue3 全方面对比
1. 编程风格 & 视图风格1.1 编程风格 React 语法少、难度大;Vue 语法多,难度小例如指令:Vue<input v-model="username"/><ul> <li v-for="(item,index) in list" :key="inde...【详细内容】
2024-01-03  爱做梦的程序员  今日头条  Tags:Vue3   点击:(74)  评论:(0)  加入收藏
站内最新
站内热门
站内头条