如何用TypeScript的元组联合重载实现函数重载?
- 内容介绍
- 文章标签
- 相关推荐
本文共计637个文字,预计阅读时间需要3分钟。
问题:TypeScript 中为函数添加多个签名后,如何判断并从不同的签名参数列表中获取对应的参数?
常见写法:typescriptfunction refEventEmitter(event?: string): void;
问题:
TypeScript 中为函数添加多个签名后,依然需要添加相应的代码来判断并从不同的签名参数列表中获取对应的参数。过去常见的写法:
function refEventEmitter(event?: string): void; function refEventEmitter(event: string, callback: () => void): void; function refEventEmitter(callback: () => void): void; function refEventEmitter( eventOrCallback?: string | (() => void), callback?: () => void, ): void { let event: string | undefined; if (typeof eventOrCallback === 'function') { callback = eventOrCallback; } else { event = eventOrCallback; } // ... }
这个过程因为将原有参数列表直接按序号拍平,参数之间的类型关联需要人肉确保正确。
本文共计637个文字,预计阅读时间需要3分钟。
问题:TypeScript 中为函数添加多个签名后,如何判断并从不同的签名参数列表中获取对应的参数?
常见写法:typescriptfunction refEventEmitter(event?: string): void;
问题:
TypeScript 中为函数添加多个签名后,依然需要添加相应的代码来判断并从不同的签名参数列表中获取对应的参数。过去常见的写法:
function refEventEmitter(event?: string): void; function refEventEmitter(event: string, callback: () => void): void; function refEventEmitter(callback: () => void): void; function refEventEmitter( eventOrCallback?: string | (() => void), callback?: () => void, ): void { let event: string | undefined; if (typeof eventOrCallback === 'function') { callback = eventOrCallback; } else { event = eventOrCallback; } // ... }
这个过程因为将原有参数列表直接按序号拍平,参数之间的类型关联需要人肉确保正确。

