Skip to content

Instantly share code, notes, and snippets.

@aaronmcadam
Forked from mkelly12/jquery.textchange.js
Created June 16, 2010 01:47
Show Gist options
  • Save aaronmcadam/440010 to your computer and use it in GitHub Desktop.
Save aaronmcadam/440010 to your computer and use it in GitHub Desktop.
jQuery Text Change Event
(function ($) {
$.event.special.textchange = {
setup: function (data, namespaces) {
$(this).bind('keyup.textchange', $.event.special.textchange.handler);
$(this).bind('cut.textchange paste.textchange input.textchange', $.event.special.textchange.delayedHandler);
},
teardown: function (namespaces) {
$(this).unbind('.textchange');
},
handler: function (event) {
$.event.special.textchange.triggerIfChanged($(this));
},
delayedHandler: function (event) {
var element = $(this);
setTimeout(function () {
$.event.special.textchange.triggerIfChanged(element);
}, 25);
},
triggerIfChanged: function (element) {
if (element.val() !== element.data('lastValue')) {
element.trigger('textchange', element.data('lastValue'));
element.data('lastValue', element.val());
}
}
};
$.event.special.hastext = {
setup: function (data, namespaces) {
var self = this;
$(this).bind('textchange', $.event.special.hastext.handler);
},
teardown: function (namespaces) {
$(this).unbind('textchange', $.event.special.hastext.handler);
},
handler: function (event, lastValue) {
$.event.special.hastext.check($(this), lastValue);
},
check: function (element, lastValue) {
if ((lastValue === '' || lastValue === undefined) && lastValue !== element.val()) {
element.trigger('hastext');
}
}
};
$.event.special.notext = {
setup: function (data, namespaces) {
$(this).bind('textchange', $.event.special.notext.handler);
},
teardown: function (namespaces) {
$(this).unbind('textchange', $.event.special.notext.handler);
},
handler: function (event, lastValue) {
if ($(this).val() === '' && $(this).val() !== lastValue) {
$(this).trigger('notext');
}
}
};
})(jQuery);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment