Difference between revisions of "Emitter in Node"

From Logic Wiki
Jump to: navigation, search
(Logger.js)
Line 42: Line 42:
 
   log(message){
 
   log(message){
 
     console.log(message);
 
     console.log(message);
 +
    this.emit('messageLogged', {id:1, url:http://'});
 
   }
 
   }
 
};
 
};
Line 47: Line 48:
 
module.exports = Logger;
 
module.exports = Logger;
 
</pre>
 
</pre>
 +
 
=== App.js ===
 
=== App.js ===
 
<pre class="brush:js;">
 
<pre class="brush:js;">

Revision as of 11:56, 12 December 2018

Sample Code

const EventEmitter = require('events');
const emitter = new EventEmitter();

//Register a listener 
emitter.on('messageLogged', function(){
   console.log('Listener called');
});

// Raise an event 
emitter.emit('messageLogged');

Registration must come before raising

Event Arguments

emitter.on('messageLogged', function(arg){
   console.log('Listener called', arg);
});

emitter.emit('messageLogged', {id:1, url:'http://...'});

Arrow Function

emitter.on('messageLogged',(arg) => {
   console.log('Listener called', arg);
});

emitter.emit('messageLogged', {id:1, url:'http://...'});

Using in a Class

Logger.js

const EventEmitter = require('events');
class Logger extends EventEmitter {

  log(message){
     console.log(message);
     this.emit('messageLogged', {id:1, url:http://'});
  }
};

module.exports = Logger;

App.js

const EventEmitter = require('events');
const logger = new Logger();

//Register a listener 
logger.on('messageLogged', (arg) => {
   console.log('Listener called', arg);
});
logger.log('message');