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

相关推荐
烛阴9 小时前
掌握 TypeScript 的边界:any, unknown, void, never 的正确用法与陷阱
前端·javascript·typescript
simple_lau13 小时前
H5资源包热更新:从下载、解压到渲染的实现方案
typescript·harmonyos·arkts
王林不想说话13 小时前
新的枚举使用方式enum-plus
前端·vue.js·typescript
烛阴1 天前
告别繁琐的类型注解:TypeScript 类型推断完全指南
前端·javascript·typescript
濮水大叔2 天前
这个Database Transaction功能多多,你用过吗?
typescript·node.js·nestjs
Ratten2 天前
06.TypeScript 元组类型、枚举类型
typescript
CptW2 天前
字节面试题:实现任务调度器(Scheduler)
面试·typescript
Ratten2 天前
04.TypeScript 函数类型
typescript
烛阴2 天前
TypeScript高手密技:解密类型断言、非空断言与 `const` 断言
前端·javascript·typescript