@jalik/observer
Make anything observable.
Introduction
The Observer design pattern is a well known pattern to create reactive applications.
You can attach observers to a form text field, then when the text field value changes, all
observers are notified of that change and thus can do something in response.
Features
- Add event listeners
- Remove event listeners
- Emit events with arguments passed to listeners
- Includes TypeScript declarations
Sandbox
Play with the lib here:
https://codesandbox.io/s/jalik-observer-demo-de16gw?file=/src/index.js
Adding an event listener
import { Observer } from '@jalik/observer'
class Person {
constructor (name) {
this.name = name
this.observer = new Observer(this)
}
on (event, observer) {
this.observer.on(event, observer)
}
say (words) {
this.observer.emit('say', words, new Date())
}
}
const karl = new Person('karl')
karl.on('say', function (words, date) {
console.log(`${this.name} said: "${words}"`)
})
karl.say('hello')
Removing an event listener
import { Observer } from '@jalik/observer'
const listener = function () {
console.log('double click detected')
observer.off('doubleClick', listener)
}
const observer = new Observer()
observer.on('doubleClick', listener)
observer.emit('doubleClick')
observer.emit('doubleClick')
Changelog
History of releases is in the changelog.
License
The code is released under the MIT License.