[Typescript] Map a Discriminated Union to an Object
We have a type Route
that is a discriminated union of the possible routes in the application. Each route has the properties search
and route
type Route =
| {
route: "/";
search: {
page: string;
perPage: string;
};
}
| { route: "/about"; search: {} }
| { route: "/admin"; search: {} }
| { route: "/admin/users"; search: {} };
Expected:
type tests = [
Expect<
Equal<
RoutesObject,
{
"/": {
page: string;
perPage: string;
};
"/about": {};
"/admin": {};
"/admin/users": {};
}
>
>
];
Way to solve the problem is by Extract the actual route type based on discriminated type:
type RoutesObject = {
[Key in Route["route"]]: Extract<Route, { route: Key }>["search"];
};
A second apparoach:
type RoutesObject = {
[R in Route as R["route"]]: R["search"];
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2019-12-13 [Algorithm] 21. Merge Two Sorted Lists
2019-12-13 [Algorithm] 387. First Unique Character in a String
2018-12-13 [Algorithom] Stack Data Structure in JavaScript
2017-12-13 [Python] Use Python Classes
2017-12-13 [Python] Understand Scope in Python
2017-12-13 [Python] Handle Exceptions to prevent crashes in Python
2017-12-13 [Python] Read and Parse Files in Python