$ npm install EventEmitter
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.
There are no dependencies. You need only npm installed and just run npm install
to grab the development dependencies.
let EM = new EventEmitter();
EM.on('foo', () => {
// some code...
});
EM.emit('foo');
let EM = new EventEmitter();
EM.once('foo', () => {
// some code...
});
EM.emit('foo');
let EM = new EventEmitter();
EM.once('foo', (bar, baz) => {
// some code...
});
EM.emit('foo', 'var 1 for bar', 'var 2 for baz');
let EM = new EventEmitter();
EM.on('foo', () => {
// some code...
});
// Note: you can use chaining.
EM
.emit('foo')
.emit('foo')
.off('foo');
// You can set maxNumberOfListeners as a parameter when creating new object.
let EM = new EventEmitter(1);
EM.on('foo', () => {
// some code...
});
// Note: it will show notification in console.
EM.on('foo', () => {
// some other code...
});
Tests are performed using mocha and expect library.
You can use JSDoc comments found within the source code.
You can grab minified versions of EventEmitter from /dist path after running gulp build
.
EM.on('foo.*', () => {
// some code...
});
EM.on('foo,bar,baz', () => {
// some code...
});
EM.onAny(() => {
// some code...
});
© 2010 - cnpmjs.org x YWFE | Home | YWFE