У меня есть алгоритм проверки (проверка по маске):
function simpleval (selector,testexp) {
jQuery(selector).focusout (function() {
get_data = jQuery(this).val();
test_data = get_data.search(testexp);
if (test_data == -1){
jQuery(this).attr('value', 'INCORRECT').css('color','red');
}
else {
this.removeAttribute('style');
}
return (test_data);
});
}
Чтобы пользователь не нажимал кнопку «Продолжить» до заполнения формы, я отключаю ее:
jQuery('#continue').attr('disabled', 'disabled');
Затем я запускаю проверку формы:
var tested_ip = /\b(([01]?\d?\d|2[0-4]\d|25[0-5])\.){3}([01]?\d?\d|2[0-4]\d|25[0-5])\b/;
ip_test = simpleval ("#dbAddress",tested_ip);
var tested_port = /\d{2,}/;
port_test = simpleval("#dbPort",tested_port);
Теперь, если оба поля (IP и номер порта) заполнены правильно, я должен включить кнопку «Продолжить».
function buttonState(){
var isValid = false;
if(ip_test=='0' && port_test=='0') {
isValid = true;
}
if (isValid) {
jQuery('#continue').attr('disabled', '')
replaceText ('#msg','IT WORKS');
}
else jQuery('#continue').attr('disabled', 'disabled');
}
jQuery('input').on('focusout', buttonState)
Что с этим не так: все работает нормально, но кнопка все еще отключена.