【类型挑战】Awaited,难度⭐️
一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第7天,点击查看活动详情。
Dear,大家好,我是“前端小鑫同学”,😇长期从事前端开发,安卓开发,热衷技术,在编程路上越走越远~
知识运用:
题目分析:
题目地址:189-easy-awaited
我们在使用Promise时往往可以通过泛型来约束最后返回时的对象类型,我们这道题就需要设计一个类型工具来得到Promise返回的这个类型。
题目解答:
测试用例:
- 约束传入的类型一定是一个Promise对象,当传入非Promise对象时将抛出错误。
- 当我们传入Promise对象时将返回对应T的类型。
- 注意的是当Promise传入的类型依旧是Promise时需要进行递归处理。
/* _____________ 测试用例 _____________ */ import { Equal, Expect } from '@type-challenges/utils' type X = Promise<string> type Y = Promise<{ field: number }> type Z = Promise<Promise<string | number>> type cases = [ Expect<Equal<MyAwaited<X>, string>>, Expect<Equal<MyAwaited<Y>, { field: number }>>, Expect<Equal<MyAwaited<Z>, string | number>>, ] // @ts-expect-error type error = MyAwaited<number>
答案及解析:
- 首要我们要通过泛型来约束传入类型为Promise类型
- 通过infer来定义 Res用来提取Promise泛型中的类型,下面为类型推断示例:
type Flatten<Type> = Type extends Array<infer Item> ? Item : Type;
- 当我们需要递归时就需要判断Res是否依旧为Promise类型,符合的话用我们设计的MyAwaited来执行。
/* _____________ 答案 _____________ */ // 当不需要递归满足测试用例 type MyAwaited<T extends Promise<any>> = T extends Promise<infer Res> ? Res : T; // 当需要递归满足测试用例 type MyAwaited<T extends Promise<any>> = T extends Promise<infer Res> ? Res extends Promise<any> ? MyAwaited<Res> : Res : T;
接下来的一题是:【类型挑战】If,难度⭐️
欢迎关注我的公众号“前端小鑫同学”,原创技术文章第一时间推送。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)