«Требуется» jQuery Validator не работает, когда значение установлено в statup - PullRequest
5 голосов
/ 23 января 2010

У меня проблема с jQuery Validator. Я хочу использовать «обязательное» свойство для ввода текста. Он не работает, если для ввода задан атрибут value с помощью кода HTML (протестировано в Firefox (3.5), а в IE 8 - в IE работает немного лучше).

История: 1. страница загружается; 2. значение очищается; 3. фокус изменен. 4. Ничего не происходит, но сообщение об ошибке должно отображаться; 5. вернуться на поле и набрать несколько символов. 6. изменение фокуса; 7. возвращение на поле; 8. Очистка поля. 9. Ошибка отображается даже перед выходом из поля.

HTML-код:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <script src="Web/Scripts/jquery-1.3.2.min.js" type="text/javascript"></script>
    <script src="Web/Scripts/jquery.validate.js" type="text/javascript"></script>    
</head>
<body>
    <form id="form1">
        <input type="text" id="name1" name="name1" value="test" /><br />
        <input type="text" />
    </form>

    <script type="text/javascript">
        $(document).ready(function() {
            var validator = $("form").validate({

                rules: {
                    name1: {
                        required: true,
                        minlength: 2
                    }
                },
                messages: {
                     name1: "bad name"
                },
            });
        });
    </script>
</body>
</html>

Ответы [ 3 ]

8 голосов
/ 18 мая 2010

Вы можете переопределить обработчик onfocusout, чтобы заставить эту работу работать так, как вы хотите (более энергично):

$(function() {
    var validator = $("form").validate({
        rules: { name1: { required: true, minlength: 2 } },
        messages: { name1: "bad name" },
        onfocusout: function(element) { $(element).valid(); }
    });
});

Вы можете увидеть старое сломанное демо (например, ваш вопрос) здесь и обновленное с onfocusout, которое работает здесь .

1 голос
/ 08 февраля 2014

для ненавязчивой проверки, когда ваш валидатор уже определен, необходимо изменить ответ Мишеля:

var validator = $('form').validate();

validator.settings.onfocusout = function(element) {
    $(element).valid();
};
/*validator.settings.onkeyup = function (element) {
    $(element).valid();
};*/
0 голосов
/ 24 января 2010

Вы забыли сказать, для какого подтверждения было сообщение: попробуйте это:

 messages: { 
             name1:
                   {
                      required : "This is a required field",
                     minlength: "Please enter 2 chars or more"
                   }
            }

Michel

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...