TypeScript 联合、交叉、字面量类型,类型别名、推导、断言

环境搭建


typescript 安装
npm install  typescript -g	// 全局安装ts
目录结构

在这里插入图片描述

tsconfig.json配置内容
{
    "compilerOptions": {
        "target": "ES2015",	// 编译的目标标准
        "outDir": "./dist",	// 编译后的文件输出目录
        "watch": true		// 进入监听模式,文件发生变动立即重新编译
    },
    "include": ["./src/**/*"]	// 编译src目录下的所有目录及文件
}

联合类型

  • 联合类型也可称为多选类型,用于标注一个变量的类型为多个类型之一
  • 标注语法:变量: 类型一 | 类型二
  • 例如,下面value的类型被限制为numberstring,其他类型将会报错

在这里插入图片描述

交叉类型

  • 交叉类型也称为合并类型,把多种类型合并到一起成为一种新的类型
  • 标注语法:变量: 类型一 | 类型二
  • 如下, obj3的类型为 o1o2 的合并
    在这里插入图片描述

字面量类型

  • 标注变量的取值只能是给定的确切值
  • 标注语法:变量: 固定值1 | 固定值2 | ...
  • 如下,direction的取值只能是固定的几个值
    在这里插入图片描述

类型别名

  • 用于给类型起另一个名字,与原类型具有相同的功能
  • 标注语法:type 新的类型名 = 类型
  • 如下,给上述的字面量类型起了个更简洁的别名,使得代码更加清晰
    在这里插入图片描述

类型推导

  • typescript可以根据上下文自动推断出变量类型,因此有的时候我们不必指定变量的类型
  • 如下图所示,typescript根据参数类型及加法操作推断出返回值是number,因此r也是number类型
    在这里插入图片描述
    在这里插入图片描述

类型断言

  • 有的时候,我们比typescript更清楚某个变量是什么类型,因此可以主动断言
  • 断言语法:变量 as 类型<类型>变量
  • 如下,我们主动告诉typescriptimg变量是HTMLImageElement类型,因此可以访问src属性。另外类型断言是一次性的,只在当前语句生效
    在这里插入图片描述
好的,让我来回答你的问题。 1. TypeScript类型保护与区分类型 类型保护是 TypeScript 中用来区分不同类型的机制,可以通过 typeof、instanceof、in 等运算符来实现。例如: ```typescript function printLength(strOrArr: string | any[]) { if (typeof strOrArr === 'string') { console.log(strOrArr.length); // string类型 } else { console.log(strOrArr.length); // 数组类型 } } ``` 2. TypeScript联合类型 联合类型是指变量可以是多种不同类型之一,可以使用“|”符号将多个类型组合起来。例如: ```typescript let numOrStr: number | string = 5; numOrStr = "hello"; ``` 3. TypeScript交叉类型 交叉类型是指将多个类型合并成一个类型,可以使用“&”符号将多个类型组合起来。例如: ```typescript interface A { a: number; } interface B { b: string; } type C = A & B; const c: C = { a: 1, b: "hello" }; ``` 4. TypeScript类型别名 类型别名是为一个类型定义一个别名,可以使用“type”关键字来定义。例如: ```typescript type MyString = string; const str: MyString = "hello"; ``` 5. TypeScript 的接口 vs. 类型别名 接口和类型别名都可以用来定义类型,但有一些不同之处。接口可以被类实现,也可以被扩展,而类型别名只能定义别名。例如: ```typescript interface Person { name: string; age: number; } type PersonAlias = { name: string; age: number; }; class Student implements Person { name: string; age: number; grade: number; constructor(name: string, age: number, grade: number) { this.name = name; this.age = age; this.grade = grade; } } type StudentAlias = PersonAlias & { grade: number; }; const student: StudentAlias = { name: "Tom", age: 18, grade: 3 }; ``` 6. TypeScript 的字符串字面量类型 字符串字面量类型是指将字符串字面量作为类型,可以使用“|”符号将多个字符串字面量组合起来。例如: ```typescript type Gender = "male" | "female"; interface Person { name: string; age: number; gender: Gender; } const person: Person = { name: "Tom", age: 18, gender: "male" }; ``` 希望这些解释能够对你有所帮助。如果你还有其他问题,可以继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tanleiDD

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值