/es-event-emitter

EventEmitter is an implementation of the Event-based architecture in JavaScript.

Primary LanguageJavaScriptMIT LicenseMIT

EventEmitter in JavaScript Build Status

Synopsis

EventEmitter is an implementation of the Event-based architecture in JavaScript.

The code is written using the ES2015 approaches, including creation of private property through WeakMap that allows you to not to check for clearing memory, and let it do to the garbage collector.

The module contains the most basic and necessary things: subscription to an event, unsubscribing from the events, running event only once, setting the maximum number of listeners.

The focus is on code readability, speed of execution, getting rid of all the excess.

You can use this library in browser either at the server as within the node.js.

Installation

npm i --save es-event-emitter
or
git clone https://github.com/Zlobin/es-event-emitter.git
cd es-event-emitter && npm i && webpack

Benchmark

Run npm start.

const EM = new EventEmitter();

EM
  .on('foo', () => 'response')
  .emit('foo');
// Manual:
es-event-emitter 100,000: 29284943 nanoseconds
Node.js native 100,000: 41954981 nanoseconds
EventEmitter2 100,000: 91033365 nanoseconds
event-emitter 100,000: 211658201 nanoseconds

// Via benchmark library:
es-event-emitter x 21,508,327 ops/sec ±0.47% (76 runs sampled)
event-emitter x 5,444,296 ops/sec ±0.40% (89 runs sampled)
EventEmitter2 x 18,105,022 ops/sec ±2.07% (74 runs sampled)
Node.js native x 17,800,136 ops/sec ±0.87% (83 runs sampled)
Fastest is es-event-emitter

Dependencies

There are no dependencies. You need only npm installed and just run npm i to grab the development dependencies.

Examples

var EM = require('es-event-emitter');
html inculde:
<script src="<PATH/TO/LIBRARY>/dist/bundle.js">
Or ES2015 import:
import EM from 'es-event-emitter';
// ...
Creating an instance.
var EM = new EventEmitter();
An usual example.
EM.on('foo', function() {
  // some code...
});

EM.emit('foo');
It will be triggered only once and then callbacks will be removed.
EM.once('foo', function() {
  // some code...
});

EM.emit('foo');
// Nothing happend.
EM.emit('foo');
Callback with parameters.
EM.once('foo', function(bar, baz) {
  // some code...
});

EM.emit('foo', 'var 1 for bar', 'var 2 for baz');
Callback's call can be ordered by "weight" parameter.
EM.on('foo', function() {
  console.log('3');
}, null, 1);

EM.on('foo', function() {
  console.log('1');
}, null, 3);

EM.on('foo', function() {
  console.log('2');
}, null, 2);

EM.emit('foo');
// 3
// 2
// 1
Chaining.
EM.on('foo', function() {
  // some code...
});

EM
  .emit('foo')
  .emit('foo')
  .off('foo');
Set maxNumberOfListeners as a parameter when creating new instance.
const EM = new EventEmitter(1);

EM.on('foo', function() {
  // some code...
});
// Note: it will show notification in console.
EM.on('foo', function() {
  // some other code...
});

Testing

Tests are performed using mocha and expect library npm test.

Building the documentation

You can use JSDoc comments found within the source code.

Todo

  1. Add event's namespace:
EM.on('foo.*', function() {
  // some code...
});
  1. Add events through comma:
EM.on('foo,bar,baz', function() {
  // some code...
});
  1. Add method "onAny" for listening each event:
EM.onAny(function() {
  // some code...
});