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