The omnipresent publish subscribe design pattern. The observers are called in the same order that they are added. If an observer throws an error when executed, the exception is caught and the execution continue to the next one.
npm install watch-notify
Require and initialize watch-notify:
var watchNotify = require("watch-notify");
var watchNotify = new WatchNotify();
Watch on a specific topic:
var handle = watchNotify.watch("topic", function handler(message) {
// this === scope
}, scope /* optional */);
The topic can also be a number:
var handle = watchNotify.watch(1337, function handler() { ... });
Notify on a specific topic:
watchNotify.notify("topic", "hi!");
Several types can be given to notify:
watchNotify.notify("topic", "message1", "message2", anObject, ...);
Remove an observer:
watchNotify.unwatch(handle);
Observe only once. The handler will be called once and then removed, so any new message on topic
won't trigger it.
var handle = watchNotify.once("topic", function handler() { ... });
Remove the handler before it's even called for the first time:
watchNotify.unwatch(handle);
- console.error when an observer throws an error to help with debugging
MIT