1.EventEmitter
Node中很多模块都能够使用EventEmitter,有了EventEmitter才能方便的进行事件的监听。下面看一下Node.js中的EventEmitter如何使用。
(1)基本使用
EventEmitter是对事件触发和事件监听功能的封装,在node.js中的event模块中,event模块只有一个对象就是EventEmitter,下面是一个最基本的使用方法:
var EventEmitter = require('events').EventEmitter; var event = new EventEmitter(); event.on('some_event', function() { console.log('some_event 事件触发'); }); setTimeout(function() { event.emit('some_event'); }, 1000);
(2)EventEmitter支持的方法
EventEmitter实例对象支持的方法列表如下:
emitter.on(name, f) //对事件name指定监听函数f
emitter.once(name, f) //与on方法类似,但是监听函数f是一次性的,使用后自动移除
emitter.listeners(name) //返回一个数组,成员是事件name所有监听函数
emitter.removeListener(name, f) //移除事件name的监听函数f
emitter.removeAllListeners(name) //移除事件name的所有监听函数
同时,事件的发布emit方法可以传入多个参数,第一个参数是定义的事件,后面其他参数回作为参数传递到监听器的回调函数中。示例如下:
var events = require('events'); var emitter = new events.EventEmitter(); emitter.on('someEvent', function(arg1, arg2) { console.log('listener1', arg1, arg2); }); emitter.on('someEvent', function(arg1, arg2) { console.log('listener2', arg1, arg2); }); emitter.emit('someEvent', 'arg1 参数', 'arg2 参数');
2.原生JavaScript实现事件的订阅/发布模式
上面的EventEmitter就是事件订阅/发布模式的实现,下面我们使用原生的JavaScript进行实现:
var EventEmitter = { topics: {}, on: function(topic, listener){ //订阅事件 if (!this.topics[topic]) { this.topics[topic] = []; } //将监听函数push到对应的数组位置,即topic事件对应listener方法 this.topics[topic].push(listener); }, emit: function(topic, data){ //第一个参数是事件名,第二个参数是传入监听器回调方法内的参数 if (!this.topics[topic] || this.topics[topic].length < 1) { return; } //对topic事件的每个监听函数,执行listener方法 this.topics[topic].forEach(function(listener){ listener(data || {}); }); } };我们可以使用上面自己定义的EventEmitter类了,比如:
EventEmitter.on("myevent", function(a){
console.log(a); //控制台打印出Hi
});
EventEmitter.emit("myevent", "Hi"); //发布事件后,控制台打印出Hi