[Typescript] Function overload :The "Instantiated with Subtype" Error
import { Equal, Expect } from "../helpers/type-utils";
const obj = {
a: 1,
b: 2,
c: 3,
} as const;
type ObjKey = keyof typeof obj;
//Type '"a"' is not assignable to type 'TKey'.
// '"a"' is assignable to the constraint of type 'TKey', but 'TKey' could be instantiated with a different subtype of constraint '"a" | "b" | "c"'.
const getObjValue = <TKey extends ObjKey>(key: TKey = "a") => {
return obj[key];
};
const one = getObjValue("a");
const oneByDefault = getObjValue();
const two = getObjValue("b");
const three = getObjValue("c");
type tests = [
Expect<Equal<typeof one, 1>>,
Expect<Equal<typeof oneByDefault, 1>>, // doesn't work
Expect<Equal<typeof two, 2>>,
Expect<Equal<typeof three, 3>>
];
Solution:
1. One overload with no param
2. One overload with param
3. Implemtation should be loosen type and compatiable with both overloads
const obj = {
a: 1,
b: 2,
c: 3,
} as const;
type ObjKey = keyof typeof obj;
// function with no param
function getObjValue(): typeof obj['a'];
// function with one param
function getObjValue<TKey extends ObjKey>(key: TKey): typeof obj[TKey];
// implementation doesn't need generic, because it can infer from function overload
// to be compatiable with both overload
// we need to add default value 'a'
function getObjValue(key: ObjKey = 'a') {
return obj[key];
}
You can also add return type for implemtation:
function getObjValue(): typeof obj['a'];
function getObjValue<TKey extends ObjKey>(key: TKey): typeof obj[TKey];
function getObjValue(key: ObjKey = 'a'): 1 | typeof obj[ObjKey] {
return obj[key];
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2022-02-08 [JS Pattern] Mixin Pattern
2021-02-08 [Bash] Understand Exit Statuses in Bash
2021-02-08 [Bash] Chmod
2021-02-08 [Bash] Create and Run Bash Scripts with Command Line Arguments
2021-02-08 [Bash] Operations against Folder
2021-02-08 [Bash] Operations against files
2019-02-08 [Functional Programming ADT] Debug a Functional JavaScript composeK Flow