@realsee/dnalogel
Version:
61 lines (60 loc) • 1.98 kB
TypeScript
interface EventMap {
[name: string]: (...args: any[]) => void | boolean;
}
/**
* 监听者模式
* @template T - 预设的监听回调类型
* @example
* ```
* new Subscribe<{
* "foo": [arg1: number, arg2: string],
* "bar": [arg: boolean],
* }>()
* ```
*/
declare class Subscribe<T extends EventMap> {
/**
* 判断是否注册了事件
* @param name - 事件类型
*/
hasListener(name: keyof T): boolean;
/**
* 注册事件
* @param name - 事件类型
* @param callback - 事件回调函数
* @param once - 是否只执行一次
* @returns 解除事件
* @template K - 预设的监听事件名称
* @template C - 回调函数函数上下文
*/
on<K extends keyof T>(name: K, callback: (...args: Parameters<T[K]>) => ReturnType<T[K]>, once?: boolean): () => void;
/**
* 注册事件(是否只执行一次)
* @param name - 事件类型
* @param callback - 事件回调函数
* @returns 解除事件
* @template K - 预设的监听事件名称
* @template C - 回调函数函数上下文
*/
once<K extends keyof T>(name: K, callback: (...args: Parameters<T[K]>) => ReturnType<T[K]>): () => void;
/**
* 解除事件
*
* 如果 name 不传的话解除对应所有事件
* 如果 name, callback 不传的话解除所有name的所有事件
* @param name - 事件类型
* @param callback - 事件回调函数
* @template K - 预设的监听事件名称
*/
off<K extends keyof T>(name?: K, callback?: (...args: Parameters<T[K]>) => ReturnType<T[K]>): void;
/**
* 触发事件
* @param name - 事件类型
* @param data - 触发事件的数据
* @returns canceled 是否被触发取消
* @template K - 预设的监听事件名称
*/
emit<K extends keyof T>(name: K, ...data: Parameters<T[K]>): boolean;
}
export { Subscribe };
export type { EventMap as SubscribeEventMap };