【前端】Typescript从入门到进阶
以下是 TypeScript 的常用知识点总结,涵盖了从基础到入门的内容,并配有代码示例:
1. TypeScript 基础
1.1 安装和配置
安装 TypeScript 并初始化配置文件:
npm install -g typescript
tsc --init
1.2 基本类型
TypeScript 提供的基本类型有 `number`、`string`、`boolean`、`null`、`undefined`、`symbol`、`bigint`、`void` 等。
let isDone: boolean = false;
let age: number = 25;
let name: string = "Alice";
let u: undefined = undefined;
let n: null = null;
1.3 数组和元组
数组和元组用来表示一组数据,其中数组是同一类型元素的集合,元组则是已知数量和类型的集合。
let list: number[] = [1, 2, 3];
let tuple: [string, number] = ["Alice", 25];
1.4 枚举 (Enum)
`enum` 用于定义一组命名常量:
enum Color {
Red = 1,
Green,
Blue
let color: Color = Color.Green;
}
2. 接口 (Interface)
接口用于定义对象的结构,包括属性和方法的类型。接口可以用于类型检查和代码提示。
```typescript
interface Person {
name: string;
age: number;
}function greet(person: Person): void {
console.log("Hello, " + person.name);
}let user: Person = { name: "Alice", age: 25 };
greet(user);
```
2.1 可选属性和只读属性
接口中的可选属性在对象中可以不存在,用 `?` 表示;只读属性使用 `readonly` 关键字修饰。
```typescript
interface Book {
readonly title: string;
author?: string;
}let book: Book = { title: "TypeScript Handbook" };
// book.title = "New Title"; // 错误:title 是只读属性
```
2.2 函数类型的接口
接口还可以用于定义函数的结构:
```typescript
interface Add {
(x: number, y: number): number;
}
const add: Add = (x, y) => x + y;
```
3. 类型别名 (Type Alias)
类型别名允许为任何类型创建一个新的名称:
```typescript
type ID = string | number;
let userId: ID = "123";
userId = 456;
```
4. 联合类型和交叉类型
4.1 联合类型 (Union Types)
联合类型表示一个值可以是几种类型之一,用 `|` 表示。
```typescript
let value: string | number;
value = "hello";
value = 42;
```
4.2 交叉类型 (Intersection Types)
交叉类型用于将多个类型合并为一个类型,用 `&` 表示。
``typescript
interface Name {
na`me: string;
}
interface Age {
age: number;
}type Person = Name & Age;
let person: Person = { name: "Alice", age: 25 };
```
5. 类 (Class) 和继承
5.1 定义类
TypeScript 支持面向对象编程,使用 `class` 关键字定义类:
```typescript
class Animal {
name: string;constructor(name: string) {
this.name = name;
}move(distance: number = 0) {
console.log(`${this.name} moved ${distance}m.`);
}
}let dog = new Animal("Dog");
dog.move(10);
```
5.2 类的继承
使用 `extends` 关键字实现继承:
```typescript
class Bird extends Animal {
fly(distance: number) {
console.log(`${this.name} flew ${distance}m.`);
}
}let bird = new Bird("Sparrow");
bird.fly(20);
```
6. 泛型 (Generics)
泛型使得函数、接口和类可以适用于多种类型。
```typescript
function identity<T>(arg: T): T {
return arg;
}let output = identity<string>("Hello");
```
6.1 泛型接口和泛型类
```typescript
interface Pair<T, U> {
first: T;
second: U;
}let p: Pair<string, number> = { first: "Alice", second: 25 };
class Stack<T> {
private items: T[] = [];
push(item: T) {
this.items.push(item);
}pop(): T | undefined {
return this.items.pop();
}
}
```
7. 类型断言 (Type Assertion)
类型断言用于告诉编译器变量的实际类型。它有两种语法:
```typescript
let someValue: any = "Hello, TypeScript";
let strLength: number = (someValue as string).length;
// 或
let strLength2: number = (<string>someValue).length;
```
8. 类型守卫 (Type Guards)
TypeScript 提供了多种类型守卫,包括 `typeof`、`instanceof` 和自定义类型守卫。
```typescript
function padLeft(value: string, padding: string | number) {
if (typeof padding === "number") {
return Array(padding + 1).join(" ") + value;
}
if (typeof padding === "string") {
return padding + value;
}
throw new Error(`Expected string or number, got '${padding}'.`);
}
```
9. 模块和命名空间
9.1 模块
模块帮助组织代码。使用 `export` 和 `import` 导出和导入模块。
```typescript
// utils.ts
export function add(x: number, y: number): number {
return x + y;
}// main.ts
import { add } from "./utils";
console.log(add(2, 3));
```
9.2 命名空间
命名空间用于将一组相关的代码放在一个命名空间下。
```typescript
namespace MathUtils {
export function add(x: number, y: number): number {
return x + y;
}
}console.log(MathUtils.add(2, 3));
```
10. 高级类型
10.1 映射类型 (Mapped Types)
映射类型可以基于已有类型创建新的类型。
type Person = {
name: string;
age: number;
}type ReadonlyPerson = {
readonly [K in keyof Person]: Person[K];
}
10.2 条件类型 (Conditional Types)
条件类型是根据条件返回不同类型的类型。
type IsString<T> = T extends string ? "string" : "not string";
type Test = IsString<string>; // "string"
type Test2 = IsString<number>; // "not string"
10.3 工具类型
TypeScript 内置了一些工具类型,如 `Partial`、`Required`、`Readonly` 等。
interface User {
name: string;
age: number;
}type PartialUser = Partial<User>; // 所有属性变为可选
type ReadonlyUser = Readonly<User>; // 所有属性变为只读
以上是 TypeScript 的基础到入门知识总结,希望对你有所帮助!
相关文章:
【前端】Typescript从入门到进阶
以下是 TypeScript 的常用知识点总结,涵盖了从基础到入门的内容,并配有代码示例: 1. TypeScript 基础 1.1 安装和配置 安装 TypeScript 并初始化配置文件: npm install -g typescript tsc --init 1.2 基本类型 TypeScript 提供…...
在 RHEL 8 | CentOS Linux release 8.5.2111上安装 Zabbix 6
1. 备份YUM源文件 cd /etc/yum.repos.d/ mkdir bak mv C* ./bak/ wget -O /etc/yum.repos.d/CentOS-Linux-BaseOS.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo yum clean all yum makecache2. 将 SELinux 设置为宽容模式,如下所示。 sudo s…...
光纤HDMI线怎么连接回音壁?
第一步:准备HDMI线、光纤线(TOSLINK线)、视频源设备、回音壁 第二步:连接HDMI线,找到视频源设备上的HDMI输出口,将HDMI线的一端插入这个接口,再把HDMI线的另一端插入回音壁的HDMI输入口。注意检…...
屏幕后期处理
1、屏幕后期处理效果 屏幕后期处理效果( Screen Post-Processing Effects)是一种在渲染管线的最后阶段应用的视觉效果,允许在场景渲染完成后对最终图像进行各种调整和效果处理,从而增强视觉体验 常见的屏幕后期处理效果有&#x…...
K8资源之endpoint资源EP资源
1 endpoint资源概述 endpoint资源在K8S中用来表s示vc与后端 Pod 之间的连接关系的对象。当创建svc时,svc根据标签是否相同或svc名字是否和ep名字相同,把svc和ip关联上。 删除svc时,会自动的删除同名的ep资源。 2 ep资源和svc的关联测试 […...
微软日志丢失事件敲响安全警钟
NEWS | 事件回顾 最近,全球最大的软件公司之一——微软,遭遇了一场罕见的日志丢失危机。据报告,从9月2日至9月19日,持续长达两周的时间里,微软的多项核心云服务,包括身份验证平台Microsoft Entra、安全信息…...
Qt生成应用程序exe
1. 将工程用MinGW编译器在release模式下编译,生成可执行文件XXX.exe,新建一个文件夹如:F:\Setup\minGW,把exe文件放到这个目录下。 2. 将该编译器的bin文件添加到PATH环境变量里:bin文件路径为:D:\Qt\Qt5.…...
C#中的HttpContent、HttpClientHandle、HttpWebRequest
C#中的HttpContent 在C#中,HttpContent 是 System.Net.Http 命名空间下的一个类,它是 HttpClient 类用来发送和接收HTTP内容的基础。HttpContent 表示HTTP请求或响应的正文内容,并且可以序列化和反序列化数据。 HttpContent 是一个抽象类&a…...
23.网工入门篇--------介绍一下园区网典型组网架构及案例实践
园区网典型组网架构主要分为小型、中型、大型三种类型,以下是详细介绍及相关案例实践: 小型园区网: 架构特点: 用户规模:适用于接入用户数量较少的场景,一般支持几个至几十个用户。覆盖范围:仅限…...
QT鼠标事件
QT鼠标事件 1.概述 这篇文章介绍如何使用事件和获取事件的信号 2.创建项目 创建一个widget类型项目,在widget.ui文件中添加一个label控件 然后在项目名称上右键选择Add new... 添加文件,选择 C Class 自定义类名Mylabel,选择基类Base …...
Ubuntu 的 ROS 操作系统turtlebot3环境搭建
引言 本文介绍如何在Ubuntu系统中为TurtleBot3配置ROS环境,包括安装和配置ROS Noetic的步骤,为PC端控制TurtleBot3提供操作指南。 安装和配置的过程分为PC设置、系统安装、依赖安装等部分,并在最后进行网络配置,确保PC端能够顺利…...
C++笔记---异常
1. 异常的概念 1.1 异常和错误 异常通常是指在程序运行中动态出现的非正常情况,这些情况往往是可以预见并可以在不停止程序的情况下动态地进行处理的。 错误通常是指那些会导致程序终止的,无法动态处理的非正常情况。例如,越界访问、栈溢出…...
Python 操作数据库:读取 Clickhouse 数据存入csv文件
import pandas as pd from clickhouse_driver import Client import timeit import logging import threading from threading import Lock from queue import Queue from typing import List, Dict, Set from contextlib import contextmanager import os import time# 配置参…...
如何找到系统中bert-base-uncased默认安装位置
问题: 服务器中无法连接huggingface,故需要自己将模型文件上传 ubuntu 可以按照这个链接下载 Bert下载和使用(以bert-base-uncased为例) - 会自愈的哈士奇 - 博客园 里面提供了giehub里面的链接 GitHub - google-research/be…...
在启动 Spring Boot 项目时,报找不到 slf4j 的错误
而且 tomcat 的启动信息不知道为什么输出出来了 问 AI 得到的解决方案: 将 pom.xml 中的如下配置替换成这样,排除这个插件 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring - boot - starter - …...
android-12-source-code--write-file-function
find /app4/lineage19_oneplus6/system/ -name "*.cpp" -type f | while read -r k ; do ( grep -i write $k | grep -i file && echo $k ;) ; done获得android::base::WriteStringToFile, 进一步修改 find /app4/lineage19_oneplus6/system/ -name &qu…...
SQL(2)
一.时间盲注 有回显时用Union带出数据,只显示是否时可用布尔盲注得出数据,那如果没有任何输出时? 比如无论查询什么,都显示success,同一个回应,无法直接从服务器注入出任何数据,但是我们可以利…...
【IC每日一题:AMBA总线--APB协议时序及Verilog实现】
AMBA总线--APB协议时序及Verilog实现 1 APB3协议1.1 APB3时序1.1.1 APB写操作1.1.2 APB读操作 2 代码2.1 apb_master2.2 apb_slave 【博客首发于微信公众号《漫谈芯片与编程》,欢迎专注一下,多谢大家】 AMBA总线是用于连接微控制器和外围设备的总线协议&…...
抢先看!为什么很多公司会强行给员工电脑加屏幕水印?千字长文来解答
2024年度热议:为什么很多公司会强行给员工电脑加屏幕水印? 有人说:概是为了让员工时刻铭记,工作就像这水印,无处不在,想逃也逃不掉! “玩归玩,闹归闹”。 本文将对此进行详尽解答&…...
【AI技术】PaddleSpeech部署方案
【AI技术】PaddleSpeech部署方案 技术介绍优点缺点 部署基础环境的搭建分步详解国内镜像源切换所需环境1 g所需环境2 vim所需环境3 cuda所需环境4 cudnn所需环境5 ssl源码拉取PaddleSpeech环境安装 部署文件分享DockerHub 技术介绍 PaddleSpeech是飞浆平台的一款TTS框架。 优…...
Unity局域网画面同步方案:FMETP STREAM低延迟多终端投射实战
1. 这不是“又一个网络同步教程”,而是解决真实产线卡点的局域网画面投射方案我第一次在客户现场看到这个需求时,是在一家做工业AR巡检系统的公司。他们刚部署完一批HoloLens 2和iPad,准备给产线工人做实时设备状态叠加显示——但问题来了&am…...
Keil C251中RTX251配置错误解决方案
1. RTX251配置错误问题解析与修复指南最近在使用Keil C251开发工具时,遇到了一个典型的RTX251实时操作系统配置问题。当尝试编译TRAFFIC2、SAMPLE或INTRPT示例项目时,系统在汇编RTXCONF.A51文件时抛出了大量"UNDEFINED SYMBOL"错误。这个问题困…...
DBSCAN与GMM串联:从盖亚天文大数据中自动发现恒星关联结构
1. 项目概述:当机器学习遇见星空在盖亚(Gaia)卫星释放出海量高精度天体测量数据之前,天文学家识别一个疏散星团的成员星,往往需要结合自行、视差、颜色-星等图(CMD)等多维信息,在复杂…...
CVPR 2019 RKD论文复现踩坑记:从理论公式到可运行的PyTorch代码全解析
CVPR 2019 RKD论文复现实战:从数学推导到工业级PyTorch实现的关键细节当我在实验室第一次尝试复现CVPR 2019的Relational Knowledge Distillation(RKD)算法时,原以为按照论文公式直接编码就能快速跑通实验。但实际动手后才发现&am…...
SQL like 与 正则 区别
SQL 中的 LIKE 和正则表达式(REGEXP 或 RLIKE)都用于模式匹配,但它们在表达能力、语法复杂度、性能上有显著区别。核心区别一览表对比维度LIKE正则表达式匹配粒度通配符(%、_)元字符、量词、字符类等表达能力弱&#x…...
完整掌握Stressapptest:高效系统稳定性测试的实用指南
完整掌握Stressapptest:高效系统稳定性测试的实用指南 【免费下载链接】stressapptest Stressful Application Test - userspace memory and IO test 项目地址: https://gitcode.com/gh_mirrors/st/stressapptest Stressful Application Test(简称…...
小学期week2记录
本周完成了发射端电路的pcb原理图绘制,还有很多不足,下周将完善pcb的布线并完成接收端电路的设计...
破解‘特质波动率之谜’?用Python回测A股创业板数据,看看风险与收益到底啥关系
特质波动率与A股创业板收益关系的Python实证研究 现象背后的思考:为什么特质波动率会引发争议? 2006年Ang等人的研究像一颗投入金融学平静湖面的石子,激起了持续至今的涟漪。他们发现了一个与传统金融理论相悖的现象:高特质波动率…...
2026最新免费图片去水印工具详细教程丨手把手教会你,一看就会
你是不是也遇到过这样的抓狂时刻:相册里翻到一张超好看的壁纸,刚想设成桌面,角落那个大大的水印瞬间让人没了心情;做课件做汇报,急需一张干净的产品图,翻遍全网不是带标的就是要付费;刷视频看到…...
eClinMed 中国人民解放军总医院第五医学中心介入超声科:基于超声的可解释性机器学习模型用于≤3cm肝细胞癌分类的开发与验证
01文献信息本次分享的文献是由中国人民解放军总医院第五医学中心介入超声科联合厦门大学附属翔安医院、南开大学医学院和福州市第一总医院超声科等55家医院在2025年2月在柳叶刀子刊《eClinicalMedicine》(中科院1区,IF10.0)上的研究“Develop…...
