jQuery 防止在 if 语句中提交表单

jQuery prevent submit of form inside of if statement

抱歉,如果有一些错误,但我是一个菜鸟,我也是第一次在 Whosebug 上发帖。

我正在尝试配置一个提交表单,它控制插入的 PIN 是否正确,如果正确则继续提交。我做了一些在线研究,发现使用 jQuery 我们可以使用函数 event.preventDefault(),我试图将它插入到我的 AJAX 请求中,但它看起来并没有停止表单从被拯救。

代码如下所示:

function verifyOTP() {
    $(".error").html("").hide();
    $(".success").html("").hide();
    var otp = $("#contomovimentato").val();
    var PIN =  $("#PINvalue").val();
    var input = {
        "otp" : otp,
        "PIN" : PIN,
        "action" : "verify_otp"
    };
    if (otp != null) {
        $.ajax({
            url : 'm_ajaxpinr.php',
            type : 'GET',
            dataType : "json",
            data : input,
            success : function(response) {
                $("." + response.type).html(response.message)
                $("." + response.type).show();
                },
            error : function() {
                alert("ss");
            }
        });
    } else {
        $(".error").html('XPIN non valido.')
        $(".error").show();
        error : function(event) { event.preventDefault(); };
    }
 //if I insert "return false;" here the submit is always blocked
}

我在 atom 上检查了括号是否正确,看起来是这样。 我应该如何使用 preventDefault() 有什么想法吗? 我还检查了 m_ajaxpinr.php 的输出是否正确,确实如此。我也试过这些但是还是不行...

    if (otp != null) {
        $.ajax({
            url : 'm_ajaxpinr.php',
            type : 'GET',
            dataType : "json",
            data : input,
            success : function(response) {
                $("." + response.type).html(response.message)
                $("." + response.type).show();
        $("form").submit(function(event) {
                    if (response.type == 'success')
                {
                    alert(response.type);
                }
                else if (response.type == 'error') 
                {
                    alert(response.type);
                    event.preventDefault();
                }
                });

如上评论所述ajax调用是异步的,你需要完成取消表单的默认操作或将event.preventDefault();放在顶部函数,如果有效则在成功函数中提交otp.

.val()不会returnnull,如果没有输入returnempty

$('#myForm').on('submit', verifyOTP);

function verifyOTP(e) {
  e.preventDefault(); // note this
  
  $(".error").html("").hide();
  $(".success").html("").hide();
  var otp = $("#contomovimentato").val();
  var PIN = $("#PINvalue").val();
  var input = {
    "otp": otp,
    "PIN": PIN,
    "action": "verify_otp"
  };

  if (otp) { // mean not null, undefined, empty, false, 0
    $.ajax({
      //url: 'm_ajaxpinr.php',
      url: 'https://httpbin.org/anything/test',
      type: 'GET',
      dataType: "json",
      data: input,
      success: function(response) {
        $("." + response.type).html(response.message)
        $("." + response.type).show();
        if(response.args.otp == 1234){
           console.log('valid otp, continue submission')
           $('#myForm').off('submit'); // remove submit event
           $('#myForm').submit(); // then submit the form
        }
        else{
          console.log('invalid pin,\nvalid pin: 1234');
        }
      },
      error: function() {
        console.log("server error, submission cancelled");
      }
    });
  } else {
    $(".error").html('XPIN non valido.')
    $(".error").show();
    console.log("otp maybe empty, submission cancelled");
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form id="myForm">
  <input id="contomovimentato">
  <button>submit</button>
</form>