any-event
:cake: 一个mini的事件管理器, 希望能在您的代码中做一块砖, 支持node/browser.
安装
npm i -S any-event
使用
import EventEmitter from 'any-event';
const emitter = new EventEmitter();
emitter.on('add', data=>{
console.log(data)
});
emitter.emit('add', 1);
方法
on(eventName, listener)
绑定事件
名称 | 类型 | 数据类型 | 是否必填 | 说明 |
---|
eventName | 参数 | `String | Symbol` | 是 |
listener | 参数 | Function | 是 | 对应的回调函数 |
emitter | 返回值 | EventEmitter | --- | 实例 |
off(eventName, listener)
解除绑定, 如果不填写listener
, 那么eventName
对应的listener
都会被移除.
名称 | 类型 | 数据类型 | 是否必填 | 说明 |
---|
eventName | 参数 | `String | Symbol` | 是 |
listener | 参数 | Function | 是 | 对应的回调函数 |
emitter | 返回值 | EventEmitter | --- | 实例 |
const callback = data=>{
alert(data)
};
emitter.on('add', callback);
emitter.on('off', callback);
emitter.emit('add', 1);
once(eventName, listener)
绑定事件, 只触发一次
名称 | 类型 | 数据类型 | 是否必填 | 说明 |
---|
eventName | 参数 | `String | Symbol` | 是 |
listener | 参数 | Function | 是 | 对应的回调函数 |
emitter | 返回值 | EventEmitter | --- | 实例 |
const callback = data=>{
alert(data)
};
emitter.once('add', callback);
emitter.emit('add', 1);
emitter.emit('add', 1);
emit(eventName [, ...args])
触发事件, 支持任意数量参数
名称 | 类型 | 数据类型 | 是否必填 | 说明 |
---|
eventName | 参数 | `String | Symbol` | 是 |
...args | 参数 | Any | 是 | 对应的回调函数 |
emitter | 返回值 | Boolean | --- | 实例 |
const callback = (a,b,c,d)=>{
console(a,b,c,d);
};
emitter.once('add', callback);
emitter.emit('add', 1,2,3,4);
destroy()
销毁实例
const callback = (a,b,c,d)=>{
console(a,b,c,d);
};
emitter.once('add', callback);
emitter.destroy();
emitter.emit('add', 1,2,3,4);