Over a million developers have joined DZone.
Platinum Partner

EventEmitter in node.js

· Performance Zone

The Performance Zone is brought to you in partnership with New Relic. Quickly learn how to use Docker and containers in general to create packaged images for easy management, testing, and deployment of software.

Sometime back I had pawed at Making promises with javascript, but the node school of thought offers an attractive pattern of EventEmitters. 

EventEmitters are very much similar to PubSub, but are more tightly coupled and give more control.

I shall try to demonstrate these EventEmiters with few simple code snippets.

// Let's make a child ;)
var child = new (require('events').EventEmitter);
 
// Child's response 
child.once("born",function(){console.log("Say : Hello World!");});
child.on("cry",function(){console.log("The child is crying!");});
child.on("laugh",function(){console.log("Awe that is cute :)");});
 
//By default listener limit is 10, it can be increased using:
child.setMaxListeners(100);
 
// Let the events emmit.
child.emit("born");
child.emit("cry");
child.emit("laugh");
 
if(child.emit("born")){
   // This wont execute 
   console.log("Born again!");
}
// Because birth is an one time event.
console.log(child.emit("born"));

Output :

Say : Hello World!
The child is crying!
Awe that is cute :)
false

On a serious note, we can use this in a real programming scenario like :

db.insert({...},function(err,Record){  
if(error) emit("insertFailed",{err:err, customer:customer});  
else emit("added",customer);  
}

Anyway happy coding! Enjoy Emitting Events :)



The Performance Zone is brought to you in partnership with New Relic. Read more about providing a framework that gets you started on the right path to move your IT services to cloud computing, and give you an understanding as to why certain applications should not move to the cloud.

Topics:

Published at DZone with permission of Hemanth HM , DZone MVB .

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}