Typescript学习笔记 | 字节青训营笔记
TypeScript简介
TypeScript是一种由*微软开发*的自由和开源的编程语言。它是JavaScript的一个超集,而且本质上TypeScript扩展了JavaScript的语法,这意味着他支持所有的 JavaScript 语法。TS在JavaScript的基础上添加了类型支持,可在任何运行的JavaScript的地方运行.
TypeScript 它是一个*静态类型检查器*,在执行之前(编译)检查程序是否存在错误,可以显示标出代码中的意外行为,并根据*值的种类进行*检查,从而降低了发生错误的可能性.
TypeScript特点:
- 可读性增强:基于语法解析TSDos,ide增强
- 可维护性增强:在编译阶段暴露大部分错误。(多人合作的大型项目中,获得更好的稳定性和开发效率)
- 包含于兼容所有JS特性,支持共存
- 支持渐进式引入与升级
对象类型
特点:对象类型在TS更加细化,对每个的对象都有自己的类型语言。<br>
**接口(interface)** :在面向对象的编程中,接口是一种规范的定义,它定义了行为和动作的规范,在程序设计里面,接口起到一种限制和规范的作用。
> **注意**:使用interface关键字定义接口一般首字母大写,并在接口名称上加上大写 I 前缀。
- **可选属性**:定义该属性可以不存在。(在该属性后加上?号)。
- **只读属性**:约束属性不可在对象初始化外赋值。(在对象的某个或某些属性前加上关键字 **readonly**,可以设置该属性为只读属性)。
- **任意属性**:约束所以对象属性都必须是该属性的子类型。
### 数组类型
**两种写法**:
```
1.
const numbers: number[] = [a,b,c]
2.
const strings: Array<string> = ['a', 'b', 'c']
```
如果是数组中既有number,又有string,该怎么写?
**联合类型(由两个或多个其他类型组成的类型,表示可以是这些类型中的任意一种)**:
```
const arr: (number | string)[] = [1,'a',2,'b']
```
函数类型
在 TypeScript 中,有两种常见的定义函数的方式——函数声明(Function Declaration)和函数表达式Function Expression)。
1. 单独指定参数,返回值类型:
// 第一第二number分别为参数num1,num2添加数字类型,第三个number则为返回值添加数字类型
function plus(num1: number, num2: number): number {
return num 1+ num2
}
plus(1,2)
1. 单独指定参数,返回值类型:
```
const add = (num1: number, num2: number): number => {
return num1 + num2
}
add(2,3)
```
**注意**:不要混淆了 TypeScript 中的 `=>` 和 ES6中的 `=>`。
- 在 TypeScript 的类型定义中,`=>` 用来表示函数的定义,**左边是输入类型,需要用括号括起来,右边是输出类型**。
- 在 ES6 中,`=>` 叫做箭头函数,应用十分广泛。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具