TypeScript基础(一)基本类型与类型运算

简介: TypeScript是一种开源的编程语言,它是JavaScript的超集,意味着所有的JavaScript代码都可以在TypeScript中运行。TypeScript添加了静态类型检查和其他一些新特性,以提高代码的可读性、可维护性和可扩展性。

引言

TypeScript是一种开源的编程语言,它是JavaScript的超集,意味着所有的JavaScript代码都可以在TypeScript中运行。TypeScript添加了静态类型检查和其他一些新特性,以提高代码的可读性、可维护性和可扩展性。

基本类型

  • number:数字
  • string:字符串
  • boolean:布尔
  • 数组
  • object: 对象
  • null 和 undefined

null和undefined是所有其他类型的子类型,它们可以赋值给其他类型

通过添加strictNullChecks:true,可以获得更严格的空类型检查,null和undefined只能赋值给自身。

1. 数字类型(number)

letage: number=25;

2. 字符串类型(string)

letname: string="John";

3. 布尔类型(boolean)

letisDone: boolean=false;

4. 数组类型(array)

letnumbers: number[] = [1, 2, 3, 4, 5];
letfruits: Array<string>= ["apple", "banana", "orange"];

5. 对象(object)

functionprintValues(obj: object) {
constvalues=Object.values(obj)
values.forEach((v) =>console.log(v))
}
printValues({
name: 'afd',
age: 33})

6. null和undefined

letnullValue: null=null;
letundefinedValue: undefined=undefined;

其他常用类型

  • void类型:通常用于约束函数的返回值,表示该函数没有任何返回
functionsayHello(): void {
console.log("Hello!");
}
  • never类型:通常用于约束函数的返回值,表示该函数永远不可能结束
functionthrowError(message: string): never {
thrownewError(message);
}
functioninfiniteLoop(): never {
while (true) {
// do something...  }
}
  • 字面量类型:使用一个值进行约束。它可以用于限制变量的取值范围,只允许特定的字面量值赋给变量
letarr: [] // arr永远只能取值为一个空数组letgender='男'|'女'
  • 元祖类型(Tuple): 一个固定长度的数组,并且数组中每一项的类型确定
letperson: [string, number] = ["John", 25];
  • any类型: any类型可以绕过类型检查,因此,any类型的数据可以赋值给任意类型
letdata: any="Hello";
data=123;

类型运算

类型运算符在TypeScript中用于对类型进行操作和组合。以下是对常见的类型运算符进行介绍:

1. 联合类型(Union Types)

使用 | 运算符将多个类型组合成一个联合类型。表示变量可以是多个类型中的任意一个。例如:

letage: number|string;
age=25; // 合法age="25"; // 合法

2. 交叉类型(Intersection Types)

使用 & 运算符将多个类型组合成一个交叉类型。表示变量具有多个类型的属性和方法。例如:

interfaceA {
name: string;
}
interfaceB {
age: number;
}
typeC=A&B;
letperson: C= {
name: "John",
age: 30};

3. 可选属性(Optional Properties)

使用 ? 运算符将属性标记为可选的。表示该属性可以存在,也可以不存在。例如:

interfacePerson {
name: string;
age?: number;
}
letperson1: Person= {
name: "John"};
letperson2: Person= {
name: "Jane",
age: 25};

4. 泛型约束(Generic Constraints)

使用 extends 关键字对泛型进行约束,限制泛型参数必须满足某些条件。例如:

interfaceLengthwise {
length: number;
}
functionlogLength<TextendsLengthwise>(arg: T): void {
console.log(arg.length);
}
logLength("Hello"); // 输出 5logLength([1, 2, 3]); // 输出 3

在这个示例中,我们使用 extends 关键字约束泛型参数 T 必须满足 Lengthwise 接口的要求,即具有 length 属性。通过泛型约束,我们可以在函数内部使用泛型参数的特定属性或方法。 这些类型运算符可以帮助开发者更灵活地操作和组合类型,提供了更强大的类型系统支持。通过合理地使用这些运算符,可以提高代码的可读性和可维护性,并增强类型安全性。

类型别名

类型别名(Type Aliases)是TypeScript中的一种特性,它允许为已有的类型定义一个别名,以提高代码的可读性和可维护性。通过类型别名,可以给复杂或重复出现的类型定义一个简洁的名称。

以下是一些使用类型别名的示例:

1. 基本类型别名

typeID=number;
letuserId: ID=123;

在这个示例中,我们使用type关键字为number类型定义了一个别名ID,然后将其用于声明变量userId

2. 联合类型别名

typeStatus="success"|"failure";
letresult: Status="success";

在这个示例中,我们使用type关键字为字符串字面量类型定义了一个联合类型别名Status,它只允许取值为"success"或"failure"。然后将其用于声明变量result

3. 复杂对象类型别名

typePoint= {
x: number;
y: number;
};
letp: Point= { x: 10, y: 20 };

在这个示例中,我们使用type关键字为对象类型定义了一个别名Point,它包含了两个属性x和y。然后将其用于声明变量p。

通过使用类型别名,我们可以将复杂的类型定义简化为一个易于理解和使用的名称。

类型约束

在TypeScript中,函数可以通过参数类型、返回值类型和函数重载等方式进行约束。以下是函数的相关约束和函数重载的示例

1. 参数类型、返回值类型约束

functionmultiply(a: number, b: number): number {
returna*b;
}
letresult=multiply(2, 3); // 返回 6

在这个示例中,函数multiply接受两个参数,都是number类型,并且返回值也是number类型。通过返回值类型的约束,我们可以确保函数返回的结果符合预期的数据类型。

2.函数重载

functiongetValue(value: string): string;
functiongetValue(value: number): number;
functiongetValue(value: string|number): string|number {
if (typeofvalue==="string") {
return"Hello, "+value;
  } elseif (typeofvalue==="number") {
returnvalue*2;
  }
thrownewError("value不是string或number类型");
}
letresult1=getValue("John"); // 返回 "Hello, John"letresult2=getValue(5); // 返回 10

在这个示例中,我们定义了一个名为getValue的函数,并使用多个重载声明来定义不同参数类型对应的返回值类型。在函数体内部,我们根据参数的类型进行不同的处理。通过函数重载,我们可以根据不同的参数类型来调用相应的函数实现。

通过参数类型约束、返回值类型约束和函数重载等方式,我们可以在TypeScript中对函数进行更精确的约束和定义,以提高代码的可读性、可维护性和可靠性。


总结

通过了解这些基本类型和类型运算,开发者可以更好地定义变量、函数参数和返回值的数据类型,并在编码过程中捕获潜在的错误。这有助于提高代码质量、减少调试时间,并增强代码的可读性、可维护性和可靠性。

目录
相关文章
|
6天前
|
JavaScript 编译器
TypeScript中类型守卫:缩小类型范围的艺术
【4月更文挑战第23天】TypeScript中的类型守卫是缩小类型范围的关键技术,它帮助我们在运行时确保值的精确类型,提升代码健壮性和可读性。类型守卫包括`typeof`(检查原始类型)、`instanceof`(检查类实例)和自定义类型守卫。通过这些方法,我们可以更好地处理联合类型、泛型和不同数据源,降低运行时错误,提高代码质量。
|
6天前
|
JavaScript 前端开发 安全
Apollo与TypeScript:强大类型检查在前端开发中的应用
Apollo与TypeScript:强大类型检查在前端开发中的应用
|
6天前
|
监控 JavaScript 安全
TypeScript在员工上网行为监控中的类型安全实践
本文演示了如何使用TypeScript在员工上网行为监控系统中实现类型安全。通过定义`Website`类型和`MonitoringData`接口,确保数据准确性和可靠性。示例展示了从监控设备获取数据和提交到网站的函数,强调了类型定义在防止错误、提升代码可维护性方面的作用。
41 7
|
5天前
|
JavaScript 前端开发
TypeScript内置类型一览(Record<string,any>等等)(下)
TypeScript内置类型一览(Record<string,any>等等)
|
5天前
|
JavaScript
TypeScript内置类型一览(Record<string,any>等等)(中)
TypeScript内置类型一览(Record<string,any>等等)
|
5天前
|
JavaScript
TypeScript内置类型一览(Record<string,any>等等)(上)
TypeScript内置类型一览(Record<string,any>等等)
|
6天前
|
JavaScript 安全 前端开发
【TypeScript技术专栏】TypeScript中的类型推断与类型守卫
【4月更文挑战第30天】TypeScript的类型推断与类型守卫是提升代码安全的关键。类型推断自动识别变量类型,减少错误,包括基础、上下文、最佳通用和控制流类型推断。类型守卫则通过`typeof`、`instanceof`及自定义函数在运行时确认变量类型,确保类型安全。两者结合使用,优化开发体验,助力构建健壮应用。
|
6天前
|
JavaScript 前端开发 开发者
【TypeScript技术专栏】TypeScript类型系统与接口详解
【4月更文挑战第30天】TypeScript扩展JavaScript,引入静态类型检查以减少错误。其类型系统包括基本类型、数组等,而接口是定义对象结构的机制。接口描述对象外形,不涉及实现,可用于规定对象属性和方法。通过声明、实现接口,以及利用可选、只读属性,接口继承和合并,TypeScript增强了代码的健壮性和维护性。学习和掌握TypeScript的接口对于大型项目开发至关重要。
|
6天前
|
JavaScript 安全 前端开发
【亮剑】TypeScript 由于其强类型的特性,直接为对象动态添加属性可能会遇到一些问题
【4月更文挑战第30天】本文探讨了在 TypeScript 中安全地为对象动态添加属性的方法。基础方法是使用索引签名,允许接受任何属性名但牺牲了部分类型检查。进阶方法是接口扩展,通过声明合并动态添加属性,保持类型安全但可能导致代码重复。高级方法利用 OOP 模式的类继承,确保类型安全但增加代码复杂性。选择哪种方法取决于应用场景、代码复杂性和类型安全性需求。
|
6天前
|
JavaScript 前端开发
TypeScript基础类型
TypeScript基础类型