Расширение JQuery Validator Plugin с помощью пользовательского метода - PullRequest
4 голосов
/ 23 июня 2009

Я добавил пользовательский метод проверки для подтверждения пароля. Тем не менее, это не имеет значения, если JSON, который я получаю:

{"success":true}

или:

{"success":false}

Поле пароль никогда не проверяется.

$(document).ready(function() {
    // Ad custom validation
    $.validator.addMethod('authenticate', function (value) { 
    $.getJSON("./json/authenticate.do",{ password: value},function(json) { 
                return (json.success == true) ? true : false;}
            ); 
    }, 'Wrong password');

    $('form#changePasswordForm').validate({
            rules: {
                 repeat_new_password: { equalTo: "#new_password"    },
                 password :  {authenticate: true}
        }, submitHandler: function(form) {
                    $(form).ajaxSubmit( {
                            dataType: "json", 
                            success: function(json) {
                            alert("foo");
                    }
        });                     
    }
});         
});

Есть идеи, что я делаю не так?

1 Ответ

7 голосов
/ 23 июня 2009

Что вы делаете неправильно, так это то, что когда вы добавляете свой собственный метод, вы никогда не возвращаете true или false из него. Вы возвращаете его в обратном вызове Ajax.

$.validator.addMethod('authenticate', function (value) { 
    $.getJSON("./json/authenticate.do",{ password: value }, function(json) { 
        // This return here is useless
        return (json.success == true) ? true : false;
    }); 
    // You need to return true or false here...
    // You could use a synchronous server call instead of asynchronous
}, 'Wrong password');

Вместо добавления пользовательского метода вы можете использовать функцию remote :

$('form#changePasswordForm').validate({
    rules: {
        repeat_new_password: { 
            equalTo: "#new_password" 
        },
        password : { 
            // This will invoke ./json/authenticate.do?password=THEVALUE_OF_THE_FIELD 
            // and all you need to do is return "true" or "false" from this server script
            remote: './json/authenticate.do' 
        }
    }, 
    messages: { 
        password: { 
            remote: jQuery.format("Wrong password")
        }
    },
    submitHandler: function(form) {
        $(form).ajaxSubmit({
            dataType: "json", 
            success: function(json) {
                alert("foo");
            }
        });                     
    }
});   

Вы можете проверить это в действии здесь .

...