Повторная проверка не подтверждена в форме - PullRequest
0 голосов
/ 10 апреля 2019

Я использую reCaptcha в форме, проблема в том, что сообщение об ошибке отображается правильно при отправке формы, но при отправке формы сообщение об ошибке не удаляется. Я хочу подтвердить recaptcha на форме отправки. Может ли кто-нибудь помочь мне решить эту проблему, я попытался с помощью нескольких методов здесь reCaptcha, если условие работает нормально, но не условие другое.

$(document).ready(function() {

  /* contact form validation */
  //function formSubmit(){
  var Validator = function(formObject) {
    this.form = $(formObject);
    var Elements = {
      name: {
        reg: /^[a-zA-Z ]{2,20}$/,
        require: true,
        error: "Not a valid name.",
      },

      email: {
        reg: /^[a-z-0-9_+.-]+\@([a-z0-9-]+\.)+[a-z0-9]{2,7}$/i,
        error: "Not a valid e-mail address.",
      },
      phone: {
        reg: /^\(?([0-9]{3})\)?[-. ]?([0-9]{3})[-. ]?([0-9]{4})$/,
        error: "Not a valid number.",
      },

      message: {
        reg: /^(?!\s*$).+/,
        error: "Message field cannot be empty.",
      },


    };

    var handleError = function(element, message) {
      element.addClass('input-error');
      var $err_msg = element.parent('div');
      $err_msg.find('.error').remove();

      var error = $('<div class="error"></div>').text(message);
      error.appendTo($err_msg);
      console.log(element);


      element.on('keypress change', function() {
        $(error).fadeOut(1000, function() {
          console.log(element);
          element.removeClass('input-error');
        });
      });

    };

    /* Select Option */

    this.validate = function() {
      var errorCount = 0;

      this.form.find("input, textarea").each(function(index, field) {
        var type = $(field).data("validation");
        var validation = Elements[type];
        if (validation !== undefined) {
          var re = new RegExp(validation.reg);
          if (validation) {
            if (!re.test($(field).val())) {
              errorCount++;
              handleError($(field), validation.error);
            }
          }
        }
      })

      return errorCount == 0;
    };
  };

  /* Submit form*/

  $(function() {

    $("#contact_form").on('submit', function(e) {
      //reCAPTCHA
      var $captcha = $('#recaptcha');
      var response = grecaptcha.getResponse();

      if (response.length === 0) {
        $('.msg-error').text("reCAPTCHA is mandatory");
        if (!$captcha.hasClass("error")) {
          $captcha.addClass("error");
        }
      } else {
        alert('test');
        $('.msg-error').text('');
        $captcha.removeClass("error");
      }


      var NoErrors = new Validator(this).validate();
      if (NoErrors == true) {
        $.ajax({
          url: this.action,
          type: this.method,
          data: $(this).serialize(),
          success: function() {
            // AJAX request finished, handle the results and error msg
            $('.success_msg').fadeIn().delay(3000).fadeOut();
            //$('input[type=text], input[type=number], input[type=email], textarea').val('').removeClass('error');
            $('input[type!="submit"], textarea').val('').removeClass('error');
            grecaptcha.reset();
            //this.reset();
          }
        });

      }
      return false;
    })

  })
  //}//formSubmit
});
#success_message {
  opacity: 0;
}

.msg-error {
  color: red;
}

.error {
  color: red;
}

.g-recaptcha.error {
  border: solid 2px red;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<script src="https://www.google.com/recaptcha/api.js"></script>
<form method="post" action="contact-form.php" id="contact_form" novalidate>
  <div class="detail">
    <label>name:</label>
    <input type="text" name="name" data-validation="name" />
  </div>
  <!--detail-->
  <div class="detail">
    <label>Email:</label>
    <input type="email" name="email" data-validation="email" />
  </div>
  <!--detail-->
  <div class="detail">
    <label>phone</label>
    <input type="number" name="phone" data-validation="phone" />
  </div>
  <!--detail-->
  <div class="detail message">
    <label>Message:</label>
    <textarea name="message" cols="30" rows="15" data-validation="message"></textarea>
  </div>
  <!--detail-->
  <span class="msg-error"></span>
  <div class="g-recaptcha" id="recaptcha" data-sitekey="6LeS4O8SAAAAALWqAVWnlcB6TDeIjDDAqoWuoyo9"></div>
  <div class="btn-container">
    <input type="submit" name="send" class="btn" value="Send" />
  </div>

  <div class="success_msg">
    <p>Form submitted Successfully</p>
  </div>
</form>
...