returnof
TypeScript icon, indicating that this package has built-in type declarations

1.1.1 • Public • Published

returnof

A workaround to get the return type of a function in TypeScript.

Install

npm install returnof

Function return type

At the moment TypeScript does not allow to get the return type of a function.

const hello = () => ({ hello: 'World' })
 
type helloReturnType = typeof hello() // ERROR

returnof allows you to get it, at the cost of (a little) more verbosity.

import returnof from 'returnof'
 
const hello = () => ({ hello: 'World' })
 
const helloReturnValue = returnof(hello)
type helloReturnType = typeof helloReturnValue // { hello: string }

At runtime, helloReturnValue will be null.

Overloaded functions

If your function is overloaded and there is an ambiguity on which one you're trying to get the return type, you can pass additional arguments:

declare function hello(): void;
declare function hello(a: number): number;
 
const helloReturnValue = returnof(hello)
type helloReturnType = typeof helloReturnValue // void
 
const helloReturnValue = returnof(hello, 42)
type helloReturnType = typeof helloReturnValue // number

If there's no ambiguity, you do not need to pass additional arguments:

declare function hello(a: number): number;
 
const helloReturnValue = returnof(hello)
type helloReturnType = typeof helloReturnValue // number

Readme

Keywords

none

Package Sidebar

Install

npm i returnof

Weekly Downloads

30

Version

1.1.1

License

MIT

Last publish

Collaborators

  • kube