UNPKG

3.33 kBMarkdownView Raw
1# event-emitter
2## Environment agnostic event emitter
3
4### Installation
5
6 $ npm install event-emitter
7
8To port it to Browser or any other (non CJS) environment, use your favorite CJS bundler. No favorite yet? Try: [Browserify](http://browserify.org/), [Webmake](https://github.com/medikoo/modules-webmake) or [Webpack](http://webpack.github.io/)
9
10### Usage
11
12```javascript
13var ee = require('event-emitter');
14
15var MyClass = function () { /* .. */ };
16ee(MyClass.prototype); // All instances of MyClass will expose event-emitter interface
17
18var emitter = new MyClass(), listener;
19
20emitter.on('test', listener = function (args) {
21 // … react to 'test' event
22});
23
24emitter.once('test', function (args) {
25 // … react to first 'test' event (invoked only once!)
26});
27
28emitter.emit('test', arg1, arg2/*…args*/); // Two above listeners invoked
29emitter.emit('test', arg1, arg2/*…args*/); // Only first listener invoked
30
31emitter.off('test', listener); // Removed first listener
32emitter.emit('test', arg1, arg2/*…args*/); // No listeners invoked
33```
34### Additional utilities
35
36#### allOff(obj) _(event-emitter/all-off)_
37
38Removes all listeners from given event emitter object
39
40#### hasListeners(obj[, name]) _(event-emitter/has-listeners)_
41
42Whether object has some listeners attached to the object.
43When `name` is provided, it checks listeners for specific event name
44
45```javascript
46var emitter = ee();
47var hasListeners = require('event-emitter/has-listeners');
48var listener = function () {};
49
50hasListeners(emitter); // false
51
52emitter.on('foo', listener);
53hasListeners(emitter); // true
54hasListeners(emitter, 'foo'); // true
55hasListeners(emitter, 'bar'); // false
56
57emitter.off('foo', listener);
58hasListeners(emitter, 'foo'); // false
59```
60
61#### pipe(source, target[, emitMethodName]) _(event-emitter/pipe)_
62
63Pipes all events from _source_ emitter onto _target_ emitter (all events from _source_ emitter will be emitted also on _target_ emitter, but not other way).
64Returns _pipe_ object which exposes `pipe.close` function. Invoke it to close configured _pipe_.
65It works internally by redefinition of `emit` method, if in your interface this method is referenced differently, provide its name (or symbol) with third argument.
66
67#### unify(emitter1, emitter2) _(event-emitter/unify)_
68
69Unifies event handling for two objects. Events emitted on _emitter1_ would be also emitted on _emitter2_, and other way back.
70Non reversible.
71
72```javascript
73var eeUnify = require('event-emitter/unify');
74
75var emitter1 = ee(), listener1, listener3;
76var emitter2 = ee(), listener2, listener4;
77
78emitter1.on('test', listener1 = function () { });
79emitter2.on('test', listener2 = function () { });
80
81emitter1.emit('test'); // Invoked listener1
82emitter2.emit('test'); // Invoked listener2
83
84var unify = eeUnify(emitter1, emitter2);
85
86emitter1.emit('test'); // Invoked listener1 and listener2
87emitter2.emit('test'); // Invoked listener1 and listener2
88
89emitter1.on('test', listener3 = function () { });
90emitter2.on('test', listener4 = function () { });
91
92emitter1.emit('test'); // Invoked listener1, listener2, listener3 and listener4
93emitter2.emit('test'); // Invoked listener1, listener2, listener3 and listener4
94```
95
96### Tests [![Build Status](https://travis-ci.org/medikoo/event-emitter.png)](https://travis-ci.org/medikoo/event-emitter)
97
98 $ npm test