TypeScript05:类型别名type

本文介绍了在JavaScript中如何定义基本类型如Gender,以及如何创建和使用User类型,包括定义User对象实例和定义一个根据Gender返回User数组的getUser函数。
摘要由CSDN通过智能技术生成

类型别名 type :对已知的一些类型定义名称。

type 类型名称 = ...
// 定义一个Gender类型,只能为"男"和"女"
type Gender = "男" | "女";
// 定义一个用户User类型
type User = {
  name: string;
  age: number;
  gender:Gender;
}
// 定义一个User类型的变量person
let person:User = {
  name: "张三",
  age: 18,
  gender: "男"
}
// 定义一个getUser函数,返回一个User类型的数组
function getUser(g: Gender ): User[] { 
  return [];
}
// 调用getUser函数,传递一个值为"男"
getUser("男")

TypeScript 中的接口和类型别名都可用于定义类型,但在一些情况下,它们有不同的使用场景。 接口用于描述对象的形状,可以用来定义对象的属性、方法和方法的参数类型。例如: ```typescript interface Person { name: string; age: number; sayHello: () => void; } const person: Person = { name: 'Tom', age: 18, sayHello() { console.log(`Hello, my name is ${this.name}`); } }; ``` 类型别名用于给一个类型定义一个新的名字,可以用来定义基本类型、联合类型、交叉类型等。例如: ```typescript type Age = number; type Name = string; type Person = { name: Name; age: Age; }; const person: Person = { name: 'Tom', age: 18, }; ``` 需要注意的是,接口和类型别名都可以用于描述函数类型: ```typescript interface Add { (a: number, b: number): number; } type Sub = (a: number, b: number) => number; const add: Add = (a, b) => a + b; const sub: Sub = (a, b) => a - b; ``` 但是,接口和类型别名在描述函数类型时有所不同。接口可以描述函数的可选参数、默认参数和剩余参数,而类型别名则不能。例如: ```typescript interface Func { (a: number, b?: number, ...rest: number[]): void; } type FuncAlias = (a: number, b?: number, ...rest: number[]) => void; const func: Func = (a, b, ...rest) => { console.log(a, b, rest); }; const funcAlias: FuncAlias = (a, b, ...rest) => { console.log(a, b, rest); }; ``` 因此,在需要描述函数类型时,建议优先使用接口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

猛扇赵四那半好嘴

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

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

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

打赏作者

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

抵扣说明:

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

余额充值