Node.js EventEmitter
- Node.js 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列。
- Node.js 里面的许多对象都会分发事件:一个 net.Server 对象会在每次有新连接时触发一个事件, 一个 fs.readStream 对象会在文件被打开的时候触发一个事件。 所有这些产生事件的对象都是 events.EventEmitter 的实例。
EventEmitter 简介
- EventEmitter 是 NodeJS 的核心模块 events 中的类,
- 用于对 NodeJS 中的事件进行统一管理,
- 用 events 特定的 API 对事件进行添加、触发和移除等操作,
- 核心方法的模式类似于发布订阅。
EventEmitte使用
- 通过require(“events”);来访问该模块。
var events = require('events');
var eventEmitter = new events.EventEmitter();
- EventEmitter 对象如果在实例化时发生错误,会触发 error 事件。当添加新的监听器时,newListener 事件会触发,当监听器被移除时,removeListener 事件被触发。
- 下面我们用一个简单的例子说明 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);
$ node event.js
some_event 事件触发
- EventEmitter 的每个事件由一个事件名和若干个参数组成,事件名是一个字符串,通常表达一定的语义。对于每个事件,EventEmitter 支持 若干个事件监听器。
- 当事件触发时,注册到这个事件的事件监听器被依次调用,事件参数作为回调函数参数传递。
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 参数');
$ node event.js
listener1 arg1 参数 arg2 参数
listener2 arg1 参数 arg2 参数
NodeJS中的事件(EventEmitter) API详解