/jquery-eventListener

Primary LanguageJavaScriptMIT LicenseMIT

jQuery eventListener plugin

When creating JavaScript classes you will run into an issue where you cannot remove event listeners once you've added them. To get this to work you typically need to assign your bind function call(s) to a property on the class. You can see this in the Example 1 below in the setupHandlers method.

The jQuery eventListener plugin makes it so you don't need to do this. Basically you can do everything the on and off methods does in jQuery. You'll just need to pass the class scope as the last argument. Check out the Example 2.

Also check out the EventListenerApp sample code and/or example http://codebelt.github.io/jquery-eventListener/

Example 1 without plugin

var DemoView = function() {
    this.isEnabled = false;

    this.setupHandlers();
    this.enable();
};

DemoView.prototype.setupHandlers = function() {
    // Bind event handlers scope here
    this.onClickHandler = this.onClick.bind(this);
    this.onMouseEnterHandler = this.onMouseEnter.bind(this);
    this.onMouseLeaveHandler = this.onMouseLeave.bind(this);
};

DemoView.prototype.enable = function() {
    if (this.isEnabled === true) { return this; }
    this.isEnabled = true;

    this.$card.on('click', this.onClickHandler);
    this.$card.on('mouseenter', this.onMouseEnterHandler);
    this.$card.on('mouseleave', this.onMouseLeaveHandler);
};

DemoView.prototype.disable = function() {
    if (this.isEnabled === false) { return this; }
    this.isEnabled = false;

    this.$card.off('click', this.onClickHandler);
    this.$card.off('mouseenter', this.onMouseEnterHandler);
    this.$card.off('mouseleave', this.onMouseLeaveHandler);
};

DemoView.prototype.onClick = function(event) {};
DemoView.prototype.onMouseEnter = function(event) {};
DemoView.prototype.onMouseLeave = function(event) {};

Example 2 with plugin

var DemoView = function() {
    this.isEnabled = false;

    this.enable();
};

DemoView.prototype.enable = function() {
    if (this.isEnabled === true) { return this; }
    this.isEnabled = true;

    this.$card.addEventListener('click', this.onClick, this);
    this.$card.addEventListener('mouseenter', this.onMouseEnter, this);
    this.$card.addEventListener('mouseleave', this.onMouseLeave, this);
};

DemoView.prototype.disable = function() {
    if (this.isEnabled === false) { return this; }
    this.isEnabled = false;

    this.$card.removeEventListener('click', this.onClick, this);
    this.$card.removeEventListener('mouseenter', this.onMouseEnter, this);
    this.$card.removeEventListener('mouseleave', this.onMouseLeave, this);
};

DemoView.prototype.onClick = function(event) {};
DemoView.prototype.onMouseEnter = function(event) {};
DemoView.prototype.onMouseLeave = function(event) {};

Add it to Your Project

bower install jquery.eventListener

RequireJS Example

Add the path to the config.js file:

require.config({
    paths: {
        ...
        'jquery.eventListener': '../vendor/jquery.eventListener/src/jquery.eventListener',
        ...
    },
    shim: {
        'jquery.eventListener': {
            exports: 'jquery.eventListener',
            deps: ['jquery']
        }
    }
});

Require it in your main file:

 require('jquery.eventListener');