在发送数据之前验证ajax submit post方法

时间:2017-05-19 17:13:08

标签: javascript php jquery ajax validation

在这种特殊情况下,我使用Google代码管理器在引导程序模式中提交表单。
我无法访问后端,这就是我使用GTM定位按钮并使用onClick的原因。

<script>
$(document).on('submit','#MyForm',function(event){
  var form = $('#MyForm');
  var submit = $('#ssend_btn');
  form.on('submit', function(e) {
    e.preventDefault();
    if($('input', this).val().trim() == ''  ){
      //handle error message
      alert("im empty and email will not send");
    }
    else if (submit != 'null' ){
      event.preventDefault()
      var formData = $(this).serialize();
      console.log(formData);
      $.ajax({
        url: "page.php", // some php
        data: formData,
        datatype: "json",
        type: "POST",
        success: function(data) {

        }
      });
    }
  });
});
</script>

发送电子邮件后,模式不能关闭,这就是我使用ajax的原因。 如果我删除了验证,我可以发送电子邮件,但即使是空白也会提交 我有其他javascript验证,但不尊重它。

<script>
function validateForm() {
  var x = document.forms["myForm"]["EMAIL"].value;
  var atpos = x.indexOf("@");
  var dotpos = x.lastIndexOf(".");
  if (atpos<1 || dotpos<atpos+2 || dotpos+2>=x.length) {
    error = "testingo";
    document.getElementById("errorid").innerHTML = error;
    return false;
  }

</script>

在控制台日志中这是我得到enter image description here电子邮件发送的方式

1 个答案:

答案 0 :(得分:1)

你正在寻找这样的东西吗?看起来你正在使用vanilla JS和jQuery的混合物;我建议在尝试引用表单和表单输入时坚持使用其中一个,以使其更容易。另外,如果您将输入的类型更改为&#34; email&#34;而不是&#34; text&#34;,内置浏览器功能(适用于Chrome等)将有助于确保除验证逻辑外还输入有效的电子邮件。

&#13;
&#13;
function validateForm() {
  if ($('#EMAIL').val().trim() === '') {
    return false;
  }
  var x = $('#EMAIL').val();
  var atpos = x.indexOf("@");
  var dotpos = x.lastIndexOf(".");
  if (atpos < 1 || dotpos < atpos + 2 || dotpos + 2 >= x.length) {
    error = "testingo";
    document.getElementById("errorid").innerHTML = error;
    return false;
  }
  return true;
}

$(document).ready(function() {

  var form = $('#MyForm');
  var submit = $('#ssend_btn');

  form.on('submit', function(e) {

    e.preventDefault();

    if (validateForm() === false) {
      //handle error message
      alert("im empty and email will not send");
    } else {
      var formData = $(this).serialize();
      console.log(formData);
      $.ajax({
        url: "page.php", // some php
        data: formData,
        datatype: "json",
        type: "POST",
        success: function(data) {

        }
      });
    }
  });
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form id="MyForm" name="MyForm">
  <input type="text" name="EMAIL" id="EMAIL" placeholder="EMAIL" />
  <div id="errorid"></div>
  <input type="submit" id="ssend_btn" value="Submit" />
</form>
&#13;
&#13;
&#13;