在启动时设置值时,jQuery Validator“required”不起作用

问题描述 投票:5回答:3

我有一个jQuery Validator的问题。我想在文本输入上使用“required”属性。当输入通过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>
jquery validation input text jquery-validate
3个回答
8
投票

你可以覆盖onfocusout处理程序,使其工作就像你想要的(更热切):

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

你可以看到old broken demo (like your question) hereupdated one with onfocusout that works here


1
投票

当您的验证器已经定义时,用于不显眼的验证已经需要修改Michel答案:

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

validator.settings.onfocusout = function(element) {
    $(element).valid();
};
/*validator.settings.onkeyup = function (element) {
    $(element).valid();
};*/

0
投票

你忘了说消息的验证方式:试试这个:

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

米歇尔

© www.soinside.com 2019 - 2024. All rights reserved.