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

相关推荐
Dragon Wu2 小时前
Electron Forge集成React Typescript完整步骤
前端·javascript·react.js·typescript·electron·reactjs
We་ct17 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
程序猿阿伟1 天前
《TypeScript中Protobuf到运行时类型安全的转换指南》
javascript·安全·typescript
We་ct1 天前
LeetCode 228. 汇总区间:解题思路+代码详解
前端·算法·leetcode·typescript
阿蒙Amon1 天前
TypeScript学习-第10章:模块与命名空间
学习·ubuntu·typescript
VT.馒头2 天前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
AAA阿giao2 天前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
hedley(●'◡'●)2 天前
基于cesium和vue的大疆司空模仿程序
前端·javascript·vue.js·python·typescript·无人机
百锦再2 天前
Vue高阶知识:利用 defineModel 特性开发搜索组件组合
前端·vue.js·学习·flutter·typescript·前端框架
小杨同学呀呀呀呀2 天前
Ant Design Vue <a-timeline>时间轴组件失效解决方案
前端·javascript·vue.js·typescript·anti-design-vue