Overloads
Function overloads в TypeScript позволяват да дефинирате множество сигнатури на функция за едно и също име на функция, което позволява тя да бъде извиквана по различни начини. Ето пример:
// Overloadsfunction sayHi(name: string): string;function sayHi(names: string[]): string[];
// Implementationfunction sayHi(name: unknown): unknown { if (typeof name === 'string') { return `Hi, ${name}!`; } else if (Array.isArray(name)) { return name.map(name => `Hi, ${name}!`); } throw new Error('Invalid value');}
sayHi('xx'); // ВалидноsayHi(['aa', 'bb']); // ВалидноЕто още един пример за използване на function overloads в рамките на class:
class Greeter { message: string;
constructor(message: string) { this.message = message; }
// overload sayHi(name: string): string; sayHi(names: string[]): ReadonlyArray<string>;
// implementation sayHi(name: unknown): unknown { if (typeof name === 'string') { return `${this.message}, ${name}!`; } else if (Array.isArray(name)) { return name.map(name => `${this.message}, ${name}!`); } throw new Error('value is invalid'); }}console.log(new Greeter('Hello').sayHi('Simon'));