Ось елегантне рішення.
Для кожного вхідного елемента форми є прихована властивість, за допомогою якої можна визначити, чи було змінено значення. Кожен тип введення має свою власну назву властивості. Наприклад
- оскільки
text/textareaце defaultValue
- для
selectце defaultSelect
- оскільки
checkbox/radioце за замовчуванням перевірено
Ось приклад.
function bindFormChange($form) {
function touchButtons() {
var
changed_objects = [],
$observable_buttons = $form.find('input[type="submit"], button[type="submit"], button[data-object="reset-form"]');
changed_objects = $('input:text, input:checkbox, input:radio, textarea, select', $form).map(function () {
var
$input = $(this),
changed = false;
if ($input.is('input:text') || $input.is('textarea') ) {
changed = (($input).prop('defaultValue') != $input.val());
}
if (!changed && $input.is('select') ) {
changed = !$('option:selected', $input).prop('defaultSelected');
}
if (!changed && $input.is('input:checkbox') || $input.is('input:radio') ) {
changed = (($input).prop('defaultChecked') != $input.is(':checked'));
}
if (changed) {
return $input.attr('id');
}
}).toArray();
if (changed_objects.length) {
$observable_buttons.removeAttr('disabled')
} else {
$observable_buttons.attr('disabled', 'disabled');
}
};
touchButtons();
$('input, textarea, select', $form).each(function () {
var $input = $(this);
$input.on('keyup change', function () {
touchButtons();
});
});
};
Тепер просто проведіть через форми на сторінці, і ви побачите, що кнопки надсилання відключені за замовчуванням, і вони будуть активовані ТІЛЬКИ, якщо ви дійсно зміните якесь вхідне значення у формі.
$('form').each(function () {
bindFormChange($(this));
});
Реалізація як jQueryплагіна тут https://github.com/kulbida/jmodifiable