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.
npm i --save es-event-emitter
or
git clone https://github.com/Zlobin/es-event-emitter.git
cd es-event-emitter && npm i && webpack
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
There are no dependencies. You need only npm installed and just run npm i
to grab the development dependencies.
var EM = require('es-event-emitter');
<script src="<PATH/TO/LIBRARY>/dist/bundle.js">
import EM from 'es-event-emitter';
// ...
var EM = new EventEmitter();
EM.on('foo', function() {
// some code...
});
EM.emit('foo');
EM.once('foo', function() {
// some code...
});
EM.emit('foo');
// Nothing happend.
EM.emit('foo');
EM.once('foo', function(bar, baz) {
// some code...
});
EM.emit('foo', 'var 1 for bar', 'var 2 for baz');
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
EM.on('foo', function() {
// some code...
});
EM
.emit('foo')
.emit('foo')
.off('foo');
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...
});
Tests are performed using mocha and expect library npm test
.
You can use JSDoc comments found within the source code.
- Add event's namespace:
EM.on('foo.*', function() {
// some code...
});
- Add events through comma:
EM.on('foo,bar,baz', function() {
// some code...
});
- Add method "onAny" for listening each event:
EM.onAny(function() {
// some code...
});