TypeScript 内置类型深度解析:原理、应用与实战

TypeScript 的内置工具类型是其类型系统最强大的特性之一,广泛用于日常开发中,帮助我们编写更加灵活、安全且可维护的代码。本文将深入解析常见内置类型的实现原理、使用场景与实战案例,并给出最佳实践建议。


一、Partial<T>:将所有属性变为可选

实现原理

ts 复制代码
type Partial<T> = {
  [P in keyof T]?: T[P];
};

通过映射类型,对 T 的每个属性 P 添加可选修饰符 ?

应用场景

  • 表单数据的局部更新
  • Redux 的局部 state 更新
  • 初始化对象但允许逐步赋值

实战案例

ts 复制代码
interface User {
  id: number;
  name: string;
  age: number;
}

function updateUser(id: number, data: Partial<User>) {
  // 只更新部分字段
}

updateUser(1, { name: 'Alice' });

二、Required<T>:将所有属性变为必填

实现原理

ts 复制代码
type Required<T> = {
  [P in keyof T]-?: T[P];
};

使用 -? 去除可选修饰符。

实战案例

ts 复制代码
interface Config {
  apiKey?: string;
  timeout?: number;
}

function init(cfg: Required<Config>) {
  // cfg.apiKey 一定存在
}

三、Readonly<T>:构造只读对象类型

实现原理

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

实战案例

ts 复制代码
interface Todo {
  title: string;
}

const todo: Readonly<Todo> = {
  title: '学习 TypeScript',
};

// todo.title = '已完成'; // ❌ 报错

四、Pick<T, K>:选取指定属性构造新类型

实现原理

ts 复制代码
type Pick<T, K extends keyof T> = {
  [P in K]: T[P];
};

实战案例

ts 复制代码
interface User {
  id: number;
  name: string;
  email: string;
  password: string;
}

// 仅展示部分字段
type PublicUser = Pick<User, 'id' | 'name'>;

五、Omit<T, K>:排除指定属性构造新类型

实现原理

ts 复制代码
type Omit<T, K extends keyof any> = Pick<T, Exclude<keyof T, K>>;
  • 使用 Exclude 去除键后再用 Pick 实现剩余字段组合。

实战案例

ts 复制代码
interface User {
  id: number;
  name: string;
  password: string;
}

type SafeUser = Omit<User, 'password'>;

六、Record<K, T>:构造对象类型

实现原理

ts 复制代码
type Record<K extends keyof any, T> = {
  [P in K]: T;
};
  • 构造具有固定键 K、统一值类型 T 的对象。

实战案例

ts 复制代码
type Role = 'admin' | 'user' | 'guest';

const permissions: Record<Role, string[]> = {
  admin: ['read', 'write', 'delete'],
  user: ['read', 'write'],
  guest: ['read'],
};

七、NonNullable:排除 null 和 undefined

实现原理

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

实战案例

ts 复制代码
type User = {
  id: number;
  name: string;
  email: string | null;
};

function getUserEmail(user: User): NonNullable<User['email']> {
  return user.email!;
}

八、总结与建议

工具类型 用途简述 应用场景
Partial 全部变为可选 表单局部更新、默认值合并
Required 全部变为必填 强制配置项、单元测试 mock
Readonly 全部变为只读 防止修改对象、React props
Pick 选出某几个属性 数据脱敏、接口层 DTO、展示字段选择
Omit 排除某几个属性 数据裁剪、避免敏感字段传输
Record 构造固定键的映射对象类型 配置映射、权限控制、状态字典等
NonNullable 排除 null 和 undefined 明确限定属性值非空

TypeScript 的内置类型工具为我们提供了强大的类型操作能力,能够帮助我们更好地管理复杂的类型关系和数据结构。通过灵活运用这些工具类型,我们可以编写出更安全、可维护的代码,提升开发效率和代码质量。

相关推荐
We་ct13 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
We་ct15 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
Async Cipher2 天前
TypeScript 的用法
前端·typescript
We་ct2 天前
LeetCode 30. 串联所有单词的子串:从暴力到高效,滑动窗口优化详解
前端·算法·leetcode·typescript
刘联其2 天前
封装一个完整的HttpClient.ts
前端·javascript·typescript
走粥2 天前
TypeScript 泛型
开发语言·前端·javascript·windows·typescript
阿蒙Amon2 天前
TypeScript学习-第3章:复合类型
javascript·学习·typescript
踢球的打工仔3 天前
typescript-接口的基本使用(三)
前端·javascript·typescript
EndingCoder3 天前
TypeScript 最新特性:跟踪版本更新
开发语言·前端·javascript·typescript
止观止3 天前
重新认识 TypeScript:不仅仅是“带类型的 JS”
javascript·typescript