İşte zarif bir çözüm.
Formda, değerin değiştirilip değiştirilmediğini belirlemek için kullanabileceğiniz her giriş öğesi için gizli özellik vardır. Her girdi türünün kendi özellik adı vardır. Örneğin
- için
text/textareabu kadar defaultValue
- için
selectbu kadar defaultSelect
- için
checkbox/radio's defaultChecked
İşte örnek.
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();
});
});
};
Şimdi sadece sayfadaki formlar arasında döngü yapın ve gönderme düğmelerinin varsayılan olarak devre dışı olduğunu görmelisiniz ve YALNIZCA formdaki bazı giriş değerlerini gerçekten değiştirirseniz bunlar etkinleştirilecektir.
$('form').each(function () {
bindFormChange($(this));
});
Bir şekilde uygulanması jQueryeklentisi burada https://github.com/kulbida/jmodifiable