2016-08-17 266 views
1

我想通过ajax执行php文件,但它只是像正常一样通过表单加载并加载一个新页面。我在这里检查了大量的代码,仍然不会通过submitHandler和ajax执行。我已经检查主机提供商和ajax支持,我已经做了jQuery的其他测试,它工作正常。只是不能让它工作。 PHP文件执行perferectly并插入数据到数据库中,所以我猜测我错过了验证代码的东西。Ajax submitHandler没有执行

$("#emailForm").validate({ 
 

 
    submitHandler: function(form) { 
 
//  event.preventDefault(); 
 
    $.ajax({ 
 
     url: $(form).attr("action"), 
 
     type: $(form).attr("method"), 
 
     data: $(form).serialize(), 
 
     success: function(response) { 
 
     document.getElementById("fee").style.display = "block"; 
 
     } 
 
    }); 
 
    return false; 
 
    } 
 
});
#fee { 
 
    display: none; 
 
}
<html> 
 

 
<head> 
 

 
    <script src="https://ajax.aspnetcdn.com/ajax/jQuery/jquery-3.1.0.min.js"></script> 
 
    <script src="https://ajax.aspnetcdn.com/ajax/jquery.validate/1.15.0/jquery.validate.min.js"></script> 
 

 
</head> 
 

 
<body> 
 
    <div class="screen"> 
 

 
    <div class="contents"> 
 
     <form class="cmxform" id="emailForm" method="post" action="process.php"> 
 
     <fieldset> 
 
      <legend>Sign up now and secure your username! 
 
      </legend> 
 
      <p> 
 
      <label for="cname">Username (required, at least 5 characters) 
 
      </label> 
 
      <input id="cname" name="name" minlength="5" type="text" required> 
 
      </p> 
 
      <p> 
 
      <label for="cpassword">Password (required, at least 8 characters) 
 
      </label> 
 
      <input id="cpassword" name="password" minlength="8" type="password" required> 
 
      </p> 
 
      <p> 
 
      <label for="cemail">Email (required) 
 
      </label> 
 
      <input id="cemail" type="email" name="email" required> 
 
      </p> 
 
      <p> 
 
      </p> 
 
      <p> 
 
      <input class="submit" type="submit" value="Submit"> 
 
      </p> 
 
     </fieldset> 
 
     </form> 
 
     <div id='fee'>Signup Complete! 
 
     </div> 
 
    </div> 
 
    </div> 
 
</body> 
 

 
</html>

+0

1)你确定你的JavaScript是执行呢? 2)你检查了控制台是否有错误? 3)我没有看到你阻止表单提交('e.preventDefault()') –

+0

ohhh!我必须防止默认?我会谷歌:) – drume

+0

@JasonP我更新了我的JavaScript,但它仍然加载在新的页面,我正在使用preventDefault正确? – drume

回答

1

与尝试,因为使用窗体对象我不知道它是使用Javascript DOM对象OT jQuery对象,所以我必须转换成对象jQuery对象和使用ATTR()方法。

$(document).ready(function() { 
 
$("#emailForm").validate({ 
 

 
    submitHandler: function(form) { 
 
    $.ajax({ 
 
     url: $(form).attr("action"), 
 
     type: $(form).attr("method"), 
 
     data: $(form).serialize(), 
 
     success: function(response) { 
 
     document.getElementById("fee").style.display = "block"; 
 
     } 
 
    }); 
 
    return false; 
 
    } 
 
}); 
 
});

+0

我已更新我的错字答案。 –

+0

这也加载了一个新的页面的PHP,谢谢! – drume

+0

你检查了我更新的答案吗? –