Ви можете дуже легко змінити val
функцію, щоб викликати зміни, замінивши її на проксі до вихідної val
функції.
просто додайте цей код десь у вашому документі (після завантаження jQuery)
(function($){
var originalVal = $.fn.val;
$.fn.val = function(){
var result =originalVal.apply(this,arguments);
if(arguments.length>0)
$(this).change(); // OR with custom event $(this).trigger('value-changed');
return result;
};
})(jQuery);
Робочий приклад: тут
(Зауважте, що це завжди спрацює, change
колиval(new_val)
викликається, навіть якщо значення насправді не змінилося.)
Якщо ви хочете викликати зміну ТІЛЬКИ, коли значення фактично змінилося, скористайтеся цим:
//This will trigger "change" event when "val(new_val)" called
//with value different than the current one
(function($){
var originalVal = $.fn.val;
$.fn.val = function(){
var prev;
if(arguments.length>0){
prev = originalVal.apply(this,[]);
}
var result =originalVal.apply(this,arguments);
if(arguments.length>0 && prev!=originalVal.apply(this,[]))
$(this).change(); // OR with custom event $(this).trigger('value-changed')
return result;
};
})(jQuery);
Живий приклад для цього: http://jsfiddle.net/5fSmx/1/