event-emitter
Environment agnostic event emitter
Installation
$ npm install event-emitter
To port it to Browser or any other (non CJS) environment, use your favorite CJS bundler. No favorite yet? Try: Browserify, Webmake or Webpack
Usage
var ee = ; var { /* .. */ };; // All instances of MyClass will expose event-emitter interface var emitter = listener; emitter; emitter; emitter; // Two above listeners invokedemitter; // Only first listener invoked emitter; // Removed first listeneremitter; // No listeners invoked
Additional utilities
allOff(obj) (event-emitter/all-off)
Removes all listeners from given event emitter object
hasListeners(obj[, name]) (event-emitter/has-listeners)
Whether object has some listeners attached to the object.
When name
is provided, it checks listeners for specific event name
var emitter = ;var hasListeners = ;var {}; ; // false emitter;; // true; // true; // false emitter;; // false
pipe(source, target[, emitMethodName]) (event-emitter/pipe)
Pipes all events from source emitter onto target emitter (all events from source emitter will be emitted also on target emitter, but not other way).
Returns pipe object which exposes pipe.close
function. Invoke it to close configured pipe.
It works internally by redefinition of emit
method, if in your interface this method is referenced differently, provide its name (or symbol) with third argument.
unify(emitter1, emitter2) (event-emitter/unify)
Unifies event handling for two objects. Events emitted on emitter1 would be also emitted on emitter2, and other way back.
Non reversible.
var eeUnify = ; var emitter1 = listener1 listener3;var emitter2 = listener2 listener4; emitter1;emitter2; emitter1; // Invoked listener1emitter2; // Invoked listener2 var unify = ; emitter1; // Invoked listener1 and listener2emitter2; // Invoked listener1 and listener2 emitter1;emitter2; emitter1; // Invoked listener1, listener2, listener3 and listener4emitter2; // Invoked listener1, listener2, listener3 and listener4
Tests
$ npm test