TypeScript学习笔记(上):TypeScript的介绍、安装及常用类型
我对TypeScript的理解就是,TypeScript是增加了类型校验的JavaScript,能够把运行期错误提升至编译期
目录
TypeScript是什么?
安装编译 TS 的工具包
运行 TS 的步骤
TypeScript 常用类型
JS 已有类型
TS 新增类型
简单数据类型
数组类型
联合类型
编辑 有括号和没有括号的区别
类型别名
函数类型
法一
法二
没有返回值的函数
有可选参数的函数
对象类型
接口
interface(接口)和 type(类型别名)的对比
通过继承实现接口中公共的属性or方法的复用
元组
类型推论
字面量类型
字面量类型配合联合类型一起使用:用来表示一组明确的可选值列表
枚举
any类型
TypeScript是什么?
TypeScript(简称:TS)是 JavaScript 的超集(JS 有的 TS 都有)。
TypeScript = Type + JavaScript(在 JS 基础之上,为 JS 添加了类型支持)。
TypeScript 是微软开发的开源编程语言,可以在任何运行 JavaScript 的地方运行。
说明:所有合法的 JS 代码都是 TS 代码,有 JS 基础只需要学习 TS 的类型即可。


安装编译 TS 的工具包
问题:为什么要安装编译 TS 的工具包?
回答:运行环境Node.js或浏览器,只认识 JS 代码,不认识 TS 代码。需要先将 TS 代码转化为 JS 代码,然后才能运行。
安装命令:npm i -g typescript。 typescript 包:用来编译 TS 代码的包,提供了 tsc 命令,实现了 TS -> JS 的转化。
验证是否安装成功:tsc -v(查看 typescript 的版本)

运行 TS 的步骤
运行方式:使用 ts-node 包,直接在 Node.js 中执行 TS 代码。
安装命令:npm i -g ts-node(ts-node 包提供了 ts-node 命令)。
使用方式:ts-node hello.ts。
解释:ts-node 命令在内部“偷偷的”将 TS -> JS,然后,再运行 JS 代码。
TypeScript 常用类型
可以将 TS 中的常用基础类型细分为两类:JS 已有类型和TS 新增类型
JS 已有类型
原始类型:number、string、boolean、null、undefined、symbol
对象类型:object(包括,数组、对象、函数等对象)
TS 新增类型
联合类型、自定义类型(类型别名)、接口、元组、字面量类型、枚举、void、any 等
简单数据类型
完全按照 JS 中类型的名称来书写即可

数组类型
两种写法,推荐使用第一种

联合类型
由两个或多个其他类型组成的类型,表示可以是这些类型中的任意一种
用 | 把可能的类型分隔开(注意不是 || )
有括号和没有括号的区别
let arr: (number | string)[] //一个数组,数组元素可以是数值型或字符串型
let arr: number | string[] //一个数字或一个字符串数组
类型别名
类型别名(自定义类型):为任意类型起别名
使用场景:当同一类型(复杂)被多次使用时,可以通过类型别名,简化该类型的使用

函数类型
法一

法二
法二只适用于函数表达式

没有返回值的函数
如果函数没有返回值,那么,函数返回值类型为:void

有可选参数的函数
可选参数:在函数中,某个或多个参数可以传也可以不传
在可传可不传的参数后面加上?
注意:可选参数只能出现在参数列表的最后

对象类型

解释:
1. 直接使用 {} 来描述对象结构。属性采用 属性名: 类型 的形式;方法采用 方法名(): 返回值类型 的形式。
2. 如果方法有参数,就在方法名后面的小括号中指定参数类型(比如:greet(name: string): void)。
3. 在一行代码中指定对象的多个属性类型时,使用 ;(分号)来分隔。
4. 如果一行代码只指定一个属性类型(通过换行来分隔多个属性类型),可以去掉 ;(分号)。
5. 方法的类型也可以使用箭头函数形式(比如:{ sayHi: () => void })
接口
当一个对象类型被多次使用时,一般会使用接口(interface)来描述对象的类型,达到复用的目的
解释:
1. 使用 interface 关键字来声明接口。
2. 接口名称(比如,此处的 IPerson),可以是任意合法的变量名称。
3. 声明接口后,直接使用接口名称作为变量的类型。
4. 因为每一行只有一个属性类型,因此,属性类型后没有 ;(分号)

interface(接口)和 type(类型别名)的对比
相同点:都可以给对象指定类型。
不同点:接口,只能为对象指定类型。
类型别名,不仅可以为对象指定类型,实际上可以为任意类型指定别名
通过继承实现接口中公共的属性or方法的复用

解释: 1. 使用 extends(继承)关键字实现了接口 Point3D 继承 Point2D。 2. 继承后,Point3D 就有了 Point2D 的所有属性和方法(此时,Point3D 同时有 x、y、z 三个属性)。
元组
元组类型和数组很像,元组类型是另一种类型的数组,它确切地知道包含多少个元素,以及特定索引对应的类型

使用 number[] 的缺点:不严谨,因为该类型的数组中可以出现任意多个数字。
更好的方式:元组(Tuple)
该示例中,元素有两个元素,每个元素的类型都是 number

类型推论
在 TS 中,某些没有明确指出类型的地方,TS 的类型推论机制会帮助提供类型。
换句话说:由于类型推论的存在,这些地方,类型注解可以省略不写!
发生类型推论的 2 种常见场景:1、在声明变量的同时完成初始化时 2、决定函数返回值时。

推荐:能省略类型注解的地方就省略(偷懒,充分利用TS类型推论的能力,提升开发效率)。
技巧:如果不知道类型,可以通过鼠标放在变量名称上,利用 VSCode 的提示来查看类型。例如不知道js中某个内置函数的返回值类型, 直接将鼠标移到函数名上,就会自动显示函数返回值
字面量类型

通过 TS 类型推论机制,可以得到答案:
1. 变量 str1 的类型为:string。
2. 变量 str2 的类型为:'Hello TS'。
解释:
1. str1 是一个变量(let),它的值可以是任意字符串,所以类型为:string。
2. str2 是一个常量(const),它的值不能变化只能是 'Hello TS',所以,它的类型为:'Hello TS'
注意:此处的 'Hello TS',就是一个字面量类型。也就是说某个特定的字符串也可以作为 TS 中的类型。 除字符串外,任意的 JS 字面量(比如,对象、数字等)都可以作为类型使用
字面量类型配合联合类型一起使用:用来表示一组明确的可选值列表
比如,在贪吃蛇游戏中,游戏的方向的可选值只能是上、下、左、右中的任意一个

枚举
枚举的功能类似于字面量类型+联合类型组合的功能,也可以表示一组明确的可选值。
枚举:定义一组命名常量。它描述一个值,该值可以是这些命名常量中的一个

解释:
1. 使用 enum 关键字定义枚举。
2. 约定枚举名称、枚举中的值以大写字母开头。
3. 枚举中的多个值之间通过 ,(逗号)分隔。
4. 定义好枚举后,直接使用枚举名称作为类型注解


解释:通过将鼠标移入 Direction.Up,可以看到枚举成员 Up 的值为 0。
注意:枚举成员是有值的,默认为:从 0 开始自增的数值。
我们把,枚举成员的值为数字的枚举,称为:数字枚举。
当然,也可以给枚举中的成员初始化值

字符串枚举:枚举成员的值是字符串。
注意:字符串枚举没有自增长行为,因此,字符串枚举的每个成员必须有初始值

any类型
原则:不推荐使用 any!这会让 TypeScript 变为 “AnyScript”(失去 TS 类型保护的优势)。 因为当值的类型为 any 时,可以对该值进行任意操作,并且不会有代码提示

解释:以上操作都不会有任何类型错误提示,即使可能存在错误!
尽可能的避免使用 any 类型,除非临时使用 any 来“避免”书写很长、很复杂的类型!
其他隐式具有 any 类型的情况:1、声明变量不提供类型也不提供默认值 2、函数参数不加类型。
注意:因为不推荐使用 any,所以,这两种情况下都应该提供类型
相关文章:
TypeScript学习笔记(上):TypeScript的介绍、安装及常用类型
我对TypeScript的理解就是,TypeScript是增加了类型校验的JavaScript,能够把运行期错误提升至编译期 目录 TypeScript是什么? 安装编译 TS 的工具包 运行 TS 的步骤 TypeScript 常用类型 JS 已有类型 TS 新增类型 简单数据类型 数组类…...
Vue3学习记录(六)--- 组合式API之依赖注入和异步组件
一、依赖注入 1、简介 在前面的笔记中,我们学习过父组件向子组件传递数据时,需要借助props来实现。但如果父组件想要向孙子组件传递数据,那就要连续使用两层props逐级向下传递,如果要接收数据的是更深层的后代组件࿰…...
JZ76 删除链表中重复的结点
/*public class ListNode {int val;ListNode next null;ListNode(int val) {this.val val;} } */import java.util.*; public class Solution {public ListNode deleteDuplication(ListNode pHead) {//初步想想法: 弄一个hashmap 然后进行key存储起来。然后 如果存…...
20.2 nginx
20.2 nginx 1. 学习目标2. 介绍2.1 正向代理2.2 反向代理2.3 动态静态资源分离2.4 nginx优缺点3. 安装3.1 Linux安装****************************************************************************************************************************************************…...
MySQL学习Day26——事务基础知识
一、数据库事务概述: 事务是数据库区别于文件系统的重要特性之一,事务会让数据始终保持一致性,能通过事务机制恢复到某个时间点,可以保证提交到数据库的修改不会因为系统崩溃而丢失 1.查看引擎支持事务的情况:只有InnoDB存储引擎支持事务 SHOW ENGINES; 2.基本概念: 事…...
three.js 射线Ray,三维空间中绘制线框
效果: 代码: <template><div><el-container><el-main><div class"box-card-left"><div id"threejs"></div> <div>{{ res1 }}</div> <div>{{ res2 }}</div><…...
【Demo】游戏小地图
简介 该Demo基于2D关卡随机生成项目进行实现,旨在初步探索游戏小地图的制作。 演示 MiniMapDemo 资源下载 百度网盘(提取码:1314) 如果这篇文章对你有帮助,请给作者点个赞吧!...
代码随想录算法训练营Day39 || leetCode 762.不同路径 || 63. 不同路径 II
62.不同路径 每一位的结果等于上方与左侧结果和 class Solution { public:int uniquePaths(int m, int n) {vector<vector<int>> dp(m,vector(n,0));for (int i 0; i < m; i) dp[i][0] 1;for (int j 0; j < n; j) dp[0][j] 1;for (int i 1; i < m; …...
Qt中parent()函数的使用
情景(需求)抽象: A类对象是B类对象的成员变量。 B类对象是A类对象的父亲。 A类对象中包含按钮,点击按钮,调用B类的成员函数。 示例: A类: #pragma once#include <QWidget> #include "ui_QtWidgetsCla…...
Python基础学习(5)流程控制
文章目录 一. 程序三大执行流程二. 分支结构1.单分支结构(if)2.双分支结构(if..else)3.多分支结构(if..elif..else) 二,缩进(tab键)三,循环结构1.while循环2.for循环①遍历字典 五.break,continue和pass语句1.break,continue2.pass Python基础学习(1)基本…...
代码随想录刷题笔记 DAY 42 | 最后一块石头的重量 II No.1049 | 目标和 No.494 | 一和零 No.474
文章目录 Day 4301. 最后一块石头的重量 II(No. 1049)<1> 题目<2> 笔记<3> 代码 02. 目标和(No. 494)<1> 题目<2> 笔记<3> 代码 03. 一和零(No. 474)<1> 题目&l…...
793.高精度乘法(acwing)
文章目录 793.高精度乘法题目描述高精度乘法 793.高精度乘法 题目描述 给定两个正整数A和B,请你计算A * B的值。 输入格式 共两行,第一行包含整数A,第二行包含整数B。 输出格式 共一行,包含A * B的值。 数据范围 1≤A的长度≤…...
考研经验|如何从考研失败中走出来?
对我来说,太丢人了 其实我在本科的时候在同学眼中,一直很优秀,每年奖学金必有我的,国家励志奖学金,国家奖学金,这种非常难拿的奖学金,我也拿过,本科期间学校有一个公费去新西兰留学的…...
SpringBoot如何修改pom依赖的默认版本号
1、找到SpringBoot父工程依赖。 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.5.RELEASE</version> </parent>2、ctrl 鼠标左键点击<artifact…...
UDP与TCP:了解这两种网络协议的不同之处
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
String、StringBuffer基本用法
一、StringBuffer基本用法 1.append():字符串连接操作 StringBuffer sb new StringBuffer();sb.append("a");sb.append("b");sb.append("c");sb.append("哈哈").append("d");System.out.println(sb);2.insert():在任意位…...
蓝桥杯刷题5--GCD和LCM
目录 1. GCD 1.1 性质 1.2 代码实现 2. LCM 2.1 代码实现 3. 习题 3.1 等差数列 3.2 Hankson的趣味题 3.3 最大比例 3.4 GCD 1. GCD 整数a和b的最大公约数是能同时整除a和b的最大整数,记为gcd(a, b) 1.1 性质 GCD有关的题目一般会考核GCD的性质。 …...
LVS+Keepalived 高可用负载均衡集群
一. 高可用集群的相关知识 1.1 高可用(HA)集群和普通集群的比较 ① 普通集群 普通的群集的部署是通过一台度器控制调配多台节点服务器进行业务请求的处理,但是仅仅是一台调度器,就会存在极大的单点故障风险,当该调度…...
【RK3288 Android6, T8PRO 快捷按键 gpio 配置上拉输入】
文章目录 【RK3288 Android6, T8PRO 快捷按键 gpio 配置上拉输入】需求开发过程尝试找到没有用的上拉gpio尝试修改pwm1的gpio的默认上拉模式 改动 【RK3288 Android6, T8PRO 快捷按键 gpio 配置上拉输入】 需求 T8pro想要模仿T10 的 快捷按键ÿ…...
鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:LoadingProgress)
用于显示加载动效的组件。 说明: 该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 子组件 无 接口 LoadingProgress() 创建加载进展组件。 从API version 9开始,该接口支持在ArkTS卡片中使…...
2026八大数据采集与数据服务工具深度测评:分级分类全解析
在数据驱动的时代,选择合适的数据工具如同挑选趁手的工具。为了帮你快速定位,本文将八款主流产品按 “数据采集工具(自助型)”和“数据服务商(成品/标注型)” 两大类别,再依据用户能力、团队规模…...
消息队列学习计划 - 阶段三:面试高频问题
消息队列学习计划 - 阶段三:面试高频问题目标:准备所有 MQ 相关面试问题,覆盖基础到进阶,能应对字节/腾讯等大厂面试 预计周期:1 周,每天 1-2 小时(以记忆和模拟为主)面试问题分类类…...
解锁多光谱图像数据集:从入门到精通的实战指南
1. 多光谱图像数据集入门指南 第一次接触多光谱数据时,我被那些五颜六色的波段图搞得晕头转向。记得当时为了搞明白WorldView-3卫星的8个波段分别代表什么,整整花了两天时间查资料。现在回头看,其实掌握多光谱数据并没有想象中那么难…...
揭秘AI Agent:不只是ChatGPT,还能自主干活的AI神器!
AI Agent是一种有目标、会思考、能自主调用工具完成任务的AI。它区别于大语言模型聊天助手,具备记忆、自主规划和行动能力。Agent类型多样,如编程、个人助理、内容生成和通用类型等。运行模式主要包括ReAct(思考行动)和Plan-and-E…...
Vivado IP核归档避坑指南:为什么你的xci文件总是路径错误?
Vivado IP核归档避坑指南:为什么你的xci文件总是路径错误? 在FPGA开发中,Vivado的IP核管理一直是让开发者又爱又恨的功能。特别是当项目需要归档、迁移或团队协作时,那些看似简单的xci文件往往会变成路径错误的"定时炸弹&quo…...
机器人终于可以“看人类视频学技能”,枢途科技入选 CVPR 2026
在具身智能加速迈向真实世界的当下,数据系统能力正成为决定机器人能力上限的核心变量。 近日,枢途科技宣布,其联合清华大学、香港中文大学等机构完成的最新研究成果——《RoboWheel: A Data Engine from Real-World Human Demonstrations fo…...
监管倒计时60天:AIAgent可解释性设计必须满足的5项ISO/IEC 23894-2023强制条款
第一章:AIAgent可解释性设计的合规性基线与监管紧迫性 2026奇点智能技术大会(https://ml-summit.org) 随着欧盟《人工智能法案》(AI Act)全面生效、美国NIST AI RMF 1.1强制纳入联邦采购流程,以及中国《生成式人工智能服务管理暂…...
从SRADSGAN看遥感图像大倍数超分辨率的挑战与突破
1. 遥感图像超分辨率的现实困境 第一次接触遥感图像超分辨率任务时,我对着x8放大的卫星图像直挠头——那些模糊成色块的建筑物轮廓,就像被打了马赛克的老照片。这其实是行业内的普遍痛点:当放大倍数超过x4时,传统超分方法生成的图…...
告别熬夜绘图!虎贲等考 AI 科研绘图:让期刊级图表一键成型
在论文写作、课题研究与期刊发表中,科研绘图是决定成果呈现质量的关键环节,更是审稿人重点关注的 “门面标准”。一张规范、清晰、数据真实的图表,能显著提升论文说服力;而粗糙、模糊、不合规的插图,往往直接导致返修甚…...
【联合仿真实战】从零搭建Adams机械臂与Simulink的闭环控制模型
1. 从开环到闭环:为什么需要控制算法? 当你已经完成Adams机械臂与Simulink的基础联合仿真对接,看着机械臂在开环控制下勉强运动时,可能会发现这些问题:末端轨迹像醉汉走路一样飘忽不定,关节角度总是偏离预期…...
