这是一个优雅的解决方案。
表单上每个输入元素都有一个隐藏属性,可用于确定该值是否已更改。每种类型的输入都有其自己的属性名称。例如
- 因为
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));
});
https://github.com/kulbida/jmodifiablejQuery在此处实现为插件