TypeScript一些常见的类型申明语法写法

TypeScript 的类型声明语法主要用于指定变量、函数参数、函数返回值等的类型。这些语法形式帮助 TypeScript 提供静态类型检查和编辑器支持,从而增强代码的可读性和可维护性。下面是一些常见的类型声明语法写法:

变量和常量类型声明

typescript 复制代码
let variableName: Type;
const constantName: Type = value;

函数参数类型声明

typescript 复制代码
function functionName(parameterName: Type): ReturnType {
    // 函数体
}

函数返回类型声明

在函数参数列表之后使用 : 后跟类型来声明函数的返回类型。

typescript 复制代码
function functionName(parameterName: Type): ReturnType {
    // 函数体
}

接口声明

接口(Interfaces)用于定义对象的结构。

typescript 复制代码
interface InterfaceName {
    propertyName: Type;
    optionalPropertyName?: Type;
}

类型别名声明

类型别名(Type Aliases)允许给一个类型起一个新名字。

typescript 复制代码
type TypeName = Type;

泛型声明

泛型(Generics)允许在定义函数、接口或类的时候不预先指定具体的类型,而在使用的时候再指定类型的一种特性。

typescript 复制代码
function functionName<T>(arg: T): T {
    // 函数体
}

interface InterfaceName<T> {
    // 接口定义
}

class ClassName<T> {
    // 类定义
}

枚举声明

枚举(Enums)用于定义一组命名的常数。

typescript 复制代码
enum EnumName {
    FirstValue,
    SecondValue,
    // etc.
}

元组声明

元组(Tuples)用于表示一个已知元素数量和类型的数组,各元素的类型不必相同。

typescript 复制代码
let tupleName: [Type1, Type2] = [value1, value2];

联合类型和交叉类型声明

联合类型(Union Types)允许一个值是几种类型之一,交叉类型(Intersection Types)则是将多个类型合并为一个类型。

typescript 复制代码
let unionVariable: Type1 | Type2;
let intersectionVariable: Type1 & Type2;

类型断言

类型断言(Type Assertions)用于告诉编译器,开发者已经知道了关于变量的类型信息。有两种语法:

typescript 复制代码
let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length; // 尖括号语法
let strLengthAs: number = (someValue as string).length; // as语法

映射类型声明

映射类型(Mapped Types)通过现有的类型创建新类型的方式,它可以遍历现有类型的属性。

typescript 复制代码
type Readonly<T> = { readonly [P in keyof T]: T[P]; }

条件类型声明

条件类型(Conditional Types)根据条件选择类型。

typescript 复制代码
type NonNullable<T> = T extends null | undefined ? never : T;

这些是 TypeScript 中常用的类型声明语法写法,通过这些语法,开发者可以在编写 TypeScript 代码时明确指定变量、参数、返回值等的类型,以利用 TypeScript 提供的静态类型检查和其他特性。

相关推荐
Asize16 分钟前
Bun + TypeScript 实战:从接口约束到 RESTful 路由设计
后端·typescript·代码规范
大家的林语冰4 小时前
超越 TypeScript,Flow 强势回归,语法高仿 TS,功能更丰富,类型更安全!
前端·javascript·typescript
用户484526255826 小时前
Bun 入门:Bun.serve 零依赖启动 HTTP 服务
typescript
meilindehuzi_a1 天前
构建基于 RESTful 架构的 TodoList 全栈应用:从前后端理论到 TypeScript/Bun 实战
架构·typescript·restful
云水一下1 天前
Vue.js从零到精通系列(七):高级特性实战——Teleport、异步组件、自定义指令与TypeScript深度结合
前端·vue.js·typescript
濮水大叔1 天前
浅论CabloyJS全栈框架提供的“两级页签”机制
typescript·node.js·next.js
Asize1 天前
Bun + TypeScript:AI 时代的后端开发入门
人工智能·typescript·bun
退休倒计时2 天前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
小林ixn2 天前
你以为你懂 + 号?看完这篇 Bun + TS 实战,才发现以前全写错了
前端·javascript·typescript
晓杰'2 天前
从0到1实现Balatro游戏后端(8):Skip Blind与Tag奖励机制设计与实现
后端·websocket·typescript·项目实战·nestjs·状态管理·游戏服务器