我有一个正在处理的表单,并且我的验证 JavaScript(jQuery 和 jQuery 验证插件)在一定程度上可以工作。我已经设置了一个 jsfiddle 以显示它的工作状态:http: //jsfiddle.net/5Ukv2/
但是,当我使用 errorPlacement 函数/参数时,它会中断。错误出现在我指定的位置,但是每当我更新输入(即任何击键)时都会添加多个错误,并且当条目根据 JavaScript 有效时,错误不会从我的 HTML 中删除: http:/ /jsfiddle.net/5Ukv2/1/
此外,一旦我输入输入字段,验证就会开始;与额外的和未删除的错误元素相比,这个问题是次要的。
我究竟做错了什么?
下面附上的代码供参考以及在 jsfiddles 中。我评论了几种方法,因为它们进行的 ajax 调用在这里不起作用,但验证的作用相同。
HTML:
<form action="email_submit.php" method="post" name="enterForm" id="enterForm"> <label for="email">输入你的邮箱来玩: <input type="text" name="email" id="email" value="" /> <input type="submit" value="Enter" name="submit" class="submit" /> </form>
JavaScript:
// JavaScript Document
$(function(){
$("#enterForm").validate({
rules: {
email: {
email: true,
required: true,
remote: {url:"email_valid.php", async:false}
}
},
messages:{
email:{
email: "Please enter a valid email address",
required: "Please enter an email address",
remote: "That is not a valid domain"
}
},
submitHandler: function(form) {
var formData = $('form').serialize();
$.ajax({
type: 'POST',
url: "email_submit.php",
data: formData,
success: function(data){
if(data.subscriber && data.valid_email)
window.location = "calendar.html";
else if( !data.valid_email)
alert("Please enter a valid email");
else if( !data.subscriber)
alert("Open sign up form");
},
error: function(data){
alert("e:" + data);
console.log(data);
},
dataType: "JSON"
});
return false;
},
errorPlacement: function (error, element){
if( element.attr("name") == "email" ){
error.insertAfter("#enterForm");
}
else
error.insertAfter(element);
}
});
});