class EventEmitter {
constructor() {
// 定义存放事件订阅的存储变量
this.listeners = {};
}
on(type, cb) {
let cbs = this.listeners[type];
if (!cbs) { // 判断是否已经有订阅
cbs = [];
}
// 订阅一则事件
cbs.push(cb);
this.listeners[type] = cbs;
return this;
}
emit(type, ...args) {
const cbs = this.listeners[type];
if (Array.isArray(cbs)) {
for (let i = 0; i < cbs.length; i++) {
const cb = cbs[i];
if (typeof cb === 'function') {
// 触发一则事件
cb(...args);
}
}
}
return this;
}
off(type, cb) {
if (cb) { // 如果有回调,则取消订阅该回调
let cbs = this.listeners[type];
cbs = cbs.filter(eMap => eMap.cb !== cb);
this.listeners[type] = cbs;
} else { // 否则取消订阅整个事件
this.listeners[type] = null;
delete this.listeners[type];
}
return this;
}
}
export default new EventEmitter();
javascript 实现订阅发布模式
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。