[Typescript] Function overload: For default value arguement

import { Equal, Expect } from "../helpers/type-utils";

const obj = {
  a: 1,
  b: 2,
  c: 3,
} as const;

type ObjKey = keyof typeof obj;

// If don't pass in arguement, default value is "a", return value will be 1
function getObjKey(): 1;
function getObjKey<TKey extends ObjKey>(key: TKey): typeof obj[TKey];
function getObjKey(key: ObjKey = "a") {
  return obj[key];
}

const one = getObjKey("a");
const oneByDefault = getObjKey();
const two = getObjKey("b");
const three = getObjKey("c");

type tests = [
  Expect<Equal<typeof one, 1>>,
  Expect<Equal<typeof oneByDefault, 1>>,
  Expect<Equal<typeof two, 2>>,
  Expect<Equal<typeof three, 3>>,
];

 

posted @   Zhentiw  阅读(19)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2022-02-02 [AWS] AWS Control Tower for multi accounts
2018-02-02 [Typescript] Build Method decorators in Typescript
2017-02-02 [Javascript] Write a function pipeline
2017-02-02 [React] Pass Data To Event Handlers with Partial Function Application
2016-02-02 [Cycle.js] Read effects from the DOM: click events
2016-02-02 [Cycle.js] Introducing run() and driver functions
2016-02-02 [Cycle.js] Customizing effects from the main function
点击右上角即可分享
微信分享提示