96SEO 2026-04-27 13:30 5
在前端开发的漫漫长河中,我们总会遇到那些让人既爱又恨的时刻。特别是当你面对后端甩过来那个拥有几十个字段、甚至包含敏感信息的庞大接口时是不是感觉头dou大了?老实说这种时候,TypeScript 的类型系统就像是一把锋利的手术刀,Neng帮你精准地剔除不需要的“脂肪”。今天咱们不聊虚的,就来好好扒一扒这把手术刀中的王牌——Pick 工具类型。我们不仅要搞懂它怎么用,geng要像那些大厂面试官期望的那样,亲手把它写出来。

想象一下这样的场景:你正在开发一个用户管理系统。后端非常贴心地给你定义了一个详尽无比的 User 接口。这里面什么dou有:ID、姓名、年龄、甚至还有密码、创建时间、Zui后登录IP等等。这kan起来hen完美,对吧?直到你需要写一个简单的“用户名片”组件。
在这个小小的卡片组件里你只需要展示 name 和 avatar。Ru果你直接把那个庞大的 User 类型套用上去,虽然代码Neng跑,但总觉得哪里不对劲。万一哪天你不小心在模板里把 password 给渲染出来了那可就是生产事故了。这时候,你心里肯定会想:“要是Neng从这个大接口里只‘挑’出我需要的这几个字段组成一个新类型就好了。”
没错,这就是 Pick 存在的意义。它的核心作用非常纯粹:从一个复杂的类型中,提取出指定的属性,从而构建一个新的、精简的类型。它就像是一个过滤器,帮你把不需要的杂质dou过滤掉,只留下Zui纯净的部分。
在 TypeScript 的内置工具库里Pick 的定义其实非常简洁。但别被它的外表骗了麻雀虽小,五脏俱全。我们先来kankan它的标准用法,感受一下它的魅力。
假设我们有一个包含敏感信息的用户接口:
interface User {
id: number;
age: number;
name: string;
password: string; // 这是一个敏感字段,绝对不Neng随便泄露
createdAt: Date;
}
现在我们要创建一个专门用于公开展示的类型,只包含 id 和 name。Ru果不使用 Pick,你可Neng得重新写一个接口,或者笨拙地去 extends 然后重写属性。这不仅啰嗦,而且一旦后端改了字段名,你的维护成本就会直线上升。
有了 Pick,一切变得优雅起来:
type PublicUser = Pick;
// 等同于:
// interface PublicUser {
// id: number;
// name: string;
// }
kan,是不是hen清爽?你告诉 TypeScript:“嘿,从 User 这个类型里帮我把 id 和 name 这两个属性挑出来。” 它就会乖乖地为你生成一个新的类型。这不仅仅是代码的简化,geng是类型安全性的提升。
Ru果你去面试字节跳动、阿里巴巴这样的大厂,考察工具类型几乎是一个绕不开的环节。面试官可不想听你背诵 Pick 的用法文档,他们geng想kan到的是:“既然你懂原理,那Neng不Neng现在手写一个 MyPick 出来?”
当面试官把白板推给你,让你在 type MyPick 的 any 处填空时你该如何思考?别慌,我们Ke以把这个过程拆解为三个清晰的步骤。这不仅是解题,geng是对 TypeScript 类型编程思维的深度训练。
我们需要定义这个工具类型的“原材料”。既然是“挑选”,那肯定得有个东西被挑,还得有个标准告诉我们挑什么。
T代表源类型。也就是那个庞大的、包含所有属性的 User 接口。
K代表键名的集合。也就是我们想要挑选的属性,比如 'id' | 'name'。
所以骨架大概是这样的:type MyPick。这hen简单,对吧?但接下来的部分才是重头戏。
这是面试中Zui容易丢分的地方,也是hen多初学者容易忽略的细节。你想想,Ru果用户传了一个 T 中根本不存在的属性怎么办?比如 MyPick。Ru果我们的类型定义不Zuo任何限制,TypeScript 可Neng会傻傻地认为这是一个合法操作,直到运行时才报错,这就失去了类型系统的意义。
为了防止这种情况,我们必须给 K 加上一把“安全锁”。K 必须是 T 中所有键的集合的子集。这就引出了两个关键概念:keyof 和 extends。
keyof T 会取出 T 所有属性名的联合类型。而 extends 在这里并不是“继承”的意思,而是“约束”。它像是一个守门员,大喊一声:“想进来?先kankan你有没有资格!”
所以我们的定义变成了:type MyPick。这就保证了传入的 K 绝对是 T 里存在的属性,否则编辑器会直接报错提示你。
拿到了合法的 K,我们就要开始构建新对象了。这里要用到 TypeScript 高级类型编程中的核心——映射类型。
语法结构是:{ : ... }。这kan起来有点像 JavaScript 中的 for...in 循环,对吧?它的作用就是遍历 K 中的每一个属性 P。
在循环体里我们需要告诉 TypeScript,这个新属性 P 的类型应该是什么?显然它应该和原类型 T 中 P 的类型保持一致。这时候,就需要用到索引访问类型,语法是 T。它的作用就是“取值”,从 T 中拿出 P 对应的类型。
把这一切拼起来完美的代码就诞生了:
type MyPick = {
: T;
};
让我们来测试一下这个杰作:
type UserName = MyPick; // 结果:{ name: string }
type UserPublicInfo = MyPick; // 结果:{ id: number; name: string }
// 下面的代码会报错,因为 'hack' 不在 User 中
// type ErrorCase = MyPick;
kan到那个红色的波浪线了吗?那就是类型系统在保护你的代码。掌握了这个模板,你不仅搞定了 Pick,也顺手拿下了 OmitReadonly 和 Partial 的底层逻辑,因为它们dou是基于映射类型和索引访问构建的。
既然我们Yi经掌握了 Pick 这个基石,其他的工具类型简直就是小菜一碟。面试官通常会接着问:“那你Neng手写一下 Omit 吗?”
其实 Omit 就是 Pick 的反面。Ru果说 Pick 是“挑选”,那 Omit 就是“排除”。它的实现思路非常巧妙:先利用 Exclude 工具类型从 keyof T 中剔除掉 K,剩下的就是我们要保留的,然后再用 Pick 的逻辑把这些剩下的属性挑出来。
// 手写 Omit
// Exclude 用于从联合类型中排除某项
type MyOmit = MyPick;
至于 Partial,它的作用是将所有属性变为可选。这只需要在映射类型里加一个问号 ? 就行了:
type MyPartial = {
?: T;
};
你kan,这些kan似高深的工具类型,剥去外壳后核心dou是我们刚才讲的那些基础概念。这就是所谓的“万变不离其宗”。
与进阶:从知其然到知其所以然在面试中回答这类题目,建议遵循一个清晰的逻辑流:先讲泛型参数,再讲类型约束,Zui后讲映射和取值。这不仅Neng展示你的代码Neng力,gengNeng体现你对 TypeScript 设计哲学的理解。
我们回顾一下关键点:
1. keyof 操作符用于获取对象所有键的联合类型。
2. extends 关键字用于泛型约束,确保类型安全。
3. 映射类型,用于遍历键名创建新类型。
4. 索引访问类型T,用于获取属性的具体类型。
TypeScript 的类型系统其实是一门独立的编程语言。想要真正精通,光靠kan文档是不够的。我强烈推荐大家去 GitHub 上找一下 type-challenges 这个项目。它就像是一个针对 TypeScript 和泛型编程Neng力的健身房,里面有一系列难度递增的题目,Neng帮你把脑子里的这些知识点彻底打通。
下次当你再使用 Pick 时希望你的脑海里浮现的不再只是一个冷冰冰的关键字,而是一套完整的、精妙的类型推导逻辑。毕竟只有理解了底层原理,才Neng以不变应万变。加油,各位“类型体操”运动员们!
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback