これがエレガントなソリューションです。
フォームの各入力要素には、値が変更されたかどうかを判断するために使用できる非表示のプロパティがあります。入力の種類ごとに、独自のプロパティ名があります。例えば
- 以下のための
text/textarea
それのはdefaultValue
- 以下のための
select
それのdefaultSelect
- 以下のための
checkbox/radio
それのdefaultChecked
これが例です。
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/jmodizable