<aside> 📌 여러 오버로딩에 동시에 해당할 수 있는 경우는 제일 먼저 선언된 오버로딩이 적용된다.
</aside>
function example(a: string): string;
function example(a: string | null): number;
function example(a: string | null): string | number {
if (a) {
return 'string';
} else {
return 0;
}
}
const result = example('example'); // const result: string
<aside> 📌 각 함수의 타입을 인터페이스의 각 항목으로 표현
</aside>
interface Add {
(x: number, y: number): number;
(x: string, y: string): string;
}
const add: Add = (x: any, y: any) => x + y;
<aside>
📌 각 함수 타입을 선언한 뒤 &
연산자로 하나로 묶으면 오버로딩과 같은 역할을 함
</aside>
type Add1 = (x: number, y: number) => number;
type Add2 = (x: string, y: string) => string;
type Add = Add1 & Add2;
const add: Add = (x: any, y: any) => x + y;