TypeScript 的类型声明语法主要用于指定变量、函数参数、函数返回值等的类型。这些语法形式帮助 TypeScript 提供静态类型检查和编辑器支持,从而增强代码的可读性和可维护性。下面是一些常见的类型声明语法写法:
变量和常量类型声明
let variableName: Type;
const constantName: Type = value;
函数参数类型声明
function functionName(parameterName: Type): ReturnType {
// 函数体
}
函数返回类型声明
在函数参数列表之后使用 :
后跟类型来声明函数的返回类型。
function functionName(parameterName: Type): ReturnType {
// 函数体
}
接口声明
接口(Interfaces)用于定义对象的结构。
interface InterfaceName {
propertyName: Type;
optionalPropertyName?: Type;
}
类型别名声明
类型别名(Type Aliases)允许给一个类型起一个新名字。
type TypeName = Type;
泛型声明
泛型(Generics)允许在定义函数、接口或类的时候不预先指定具体的类型,而在使用的时候再指定类型的一种特性。
function functionName<T>(arg: T): T {
// 函数体
}
interface InterfaceName<T> {
// 接口定义
}
class ClassName<T> {
// 类定义
}
枚举声明
枚举(Enums)用于定义一组命名的常数。
enum EnumName {
FirstValue,
SecondValue,
// etc.
}
元组声明
元组(Tuples)用于表示一个已知元素数量和类型的数组,各元素的类型不必相同。
let tupleName: [Type1, Type2] = [value1, value2];
联合类型和交叉类型声明
联合类型(Union Types)允许一个值是几种类型之一,交叉类型(Intersection Types)则是将多个类型合并为一个类型。
let unionVariable: Type1 | Type2;
let intersectionVariable: Type1 & Type2;
类型断言
类型断言(Type Assertions)用于告诉编译器,开发者已经知道了关于变量的类型信息。有两种语法:
let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length; // 尖括号语法
let strLengthAs: number = (someValue as string).length; // as语法
映射类型声明
映射类型(Mapped Types)通过现有的类型创建新类型的方式,它可以遍历现有类型的属性。
type Readonly<T> = { readonly [P in keyof T]: T[P]; }
条件类型声明
条件类型(Conditional Types)根据条件选择类型。
type NonNullable<T> = T extends null | undefined ? never : T;
这些是 TypeScript 中常用的类型声明语法写法,通过这些语法,开发者可以在编写 TypeScript 代码时明确指定变量、参数、返回值等的类型,以利用 TypeScript 提供的静态类型检查和其他特性。
原文链接:https://juejin.cn/post/7355448284490498098 作者:元光六年