[Typescript] Function Overloads vs. Union Types

Union type:

function runGenerator(generator: { run: () => string } | (() => string)) {
  if (typeof generator === 'function') {
    return generator();
  }
  return generator.run();
}

vs

function overload:

function runGenerator(generator: { run: () => string }): string;
function runGenerator(generator: () => string): string;
function runGenerator(generator: { run: () => string } | (() => string)) {
  if (typeof generator === 'function') {
    return generator();
  }
  return generator.run();
}

 

When the function return type is the same, we should condier to use Union type.

 

But when the function return type is different based on input arguement, then we should condier to use function overload:

function runGenerator(generator: { run: () => string }): { result: string };
function runGenerator(generator: () => string): string;
function runGenerator(
  generator: { run: () => string } | (() => string)
): string | { result: string } {
  if (typeof generator === 'function') {
    return { result: generator() };
  }
  return generator.run();
}

 

posted @   Zhentiw  阅读(23)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2021-01-31 [Docker] Allow Containers to Communicate through Docker Networks
2019-01-31 [Functional Programming Monad] Refactor Stateful Code To Use A State Monad
2019-01-31 [Functional Programming Monad] Apply Stateful Computations To Functions (.ap, .liftA2)
2019-01-31 [Tools] Batch Create Markdown Files from a Template with Node.js and Mustache
2019-01-31 [Angular] Extract Implementation Details of ngrx from an Angular Application with the Facade Pattern
2018-01-31 [React] Refactor a Stateful List Component to a Functional Component with React PowerPlug
2018-01-31 [MST] Use Volatile State and Lifecycle Methods to Manage Private State
点击右上角即可分享
微信分享提示