Ammer
Ammer is a proof of concept, building a DOM-event-wrapper with the powers of object-getters and the Proxy
-object.
Therefore it does only work in Firefox and Microsoft Edge. Please don't use it in production!
The idea is to specify the event by calling a method, instead of passing the name as a string to a function.
Installation
$ npm install --save ammer
Usage
First you have to import the ammer
-object.
import { ammer } from 'ammer';
var ammer = require('ammer');
require(['ammer'], function (ammer) { ... });
var ammer = window.ammer;
Then you have to create an instance. After that you can start binding and unbinding DOM-events.
var amr = ammer.create();
amr.on.click(document.body, function () {
console.log('Clicked the body.');
});
amr.off.click(document.body);
You can optionally pass the callback-function to the off
-method, as well, to not remove all bindings for an event-type.
var amr = ammer.create();
function onMouseEnter() {
console.log('Mouse did enter ...');
}
amr.on.mouseenter(document.querySelector('#hover-me'), onMouseEnter);
amr.off.mouseenter(document.querySelector('#hover-me'), onMouseEnter);
All other mouseenter
-bindings to this element aren't affected.
How does it work
The on
- and off
-methods of the ammer
-object set the current mode (addListener
or removeListener
) and return a Proxy
-instance, that handles all the get
-calls. Thus it's possible to call all the event-name-methods, though they aren't explicitly defined.
License
Beerware