一直在尝试使用 jQuery 拼凑两个函数。在表单上提交时,代码会检查是否所有字段都已填写,然后如果所有这些都正确,它会移动到另一个检查电子邮件验证的功能。
我想我已经接近了,因为当我按下提交时,验证警报会显示一毫秒然后提交(我不希望它这样做,因为使用的电子邮件无效)。我很确定它的代码足够简单,因此我远离任何表单验证。
这是代码:
<script type="text/javascript">
$("#test").submit(function(){
$(".error").hide();
var isFormValid = true;
$(".required").each(function(){
if ($.trim($(this).val()).length == 0){
$(this).addClass("highlight");
isFormValid = false;
}
else{
$(this).removeClass("highlight");
}
});
if (!isFormValid) {
document.getElementById("error").innerHTML = "You must fill in all of the fields.";
return isFormValid;
}
else {
myFunction();
}
});
function myFunction() {
var isEmailValid = true;
var emailReg = /^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/;
var emailaddressVal = $("#email").val();
if (!emailReg.test(emailaddressVal)) {
$("#email").after('<span class="error">Enter a valid email address.</span>');
isEmailValid = false;
}
else {
///ajax post function here///
}
if(!isEmailValid) {
document.getElementById("error").innerHTML = "Please enter a valid email address.";
return isEmailValid;
}
}
</script>