jQueryを使用して2つの関数をつなぎ合わせようとしています。フォームで送信すると、コードはすべてのフィールドが入力されているかどうかを確認し、すべてが正しい場合は、電子メールの検証をチェックする別の関数に移動します。
送信を押すと、検証アラートがミリ秒表示されてから送信されるので、私は近いと思います(使用された電子メールが無効であるため、これは望ましくありません)。コードは十分に単純であると確信しているため、フォームの検証は避けました。
コードは次のとおりです。
<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>