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

相关推荐
路光.6 小时前
触发事件,按钮loading状态,封装hooks
前端·typescript·vue3hooks
一份执念19 小时前
TypeScript 与vue3进行项目开发,JSX 元素隐式具有类型 'any'",template中引用方法与变量找不到的问题处理
vue.js·typescript
归于尽2 天前
我扒光了mitt的源码,发现了这些不为人知的秘密
前端·typescript
铃铃六2 天前
typescript中tpye和interface的区别
前端·typescript
十步杀一人_千里不留行2 天前
I Built an Offline-Capable App by Myself: React Native Frontend, C# Backend
前端·react native·typescript
Sun_light2 天前
从 0 到 1 实现低代码编辑器的基本功能
前端·react.js·typescript
薛定谔的猫22 天前
type-challenges系列(一):Easy难度合集
前端·typescript
汪叽家的兔子羡2 天前
vue模块化导入
前端·javascript·vue.js·typescript·vue3·vue2·vite
薛定谔的猫22 天前
type-challenges系列(番外):技巧与知识点
前端·typescript