2013-07-10 119 views
1

我有一个相当基本的电子邮件形式如何在不刷新当前页面的情况下提交表单?

<form name="contactform" method="post" action="send_email.php" id="email_form"> 
    <div class="ContactHeaders">Name</div> 
    <input type="text" name="Name" class="ContactBoxes" id="name"/><br/><br/> 
    <div class="ContactHeaders">Email</div> 
    <input type="email" name="Email" class="ContactBoxes"/><br/><br/> 
    <div class="ContactHeaders">Message</div> 
    <div style="width:100%"> 
    <textarea name="Message" maxlength="1000"></textarea><br/> 
    </div> 
    <div style="width: 100%"> 
    <input type="submit" class="Submitbtn" value="Submit"> 
    </div> 
</form> 

这里的“send_email.php”

<?php 
ob_start(); 
include 'navbar.php'; 
ob_end_clean(); 

if(isset($_POST['Email'])) { 

    //declare variables 
    $Name = $_POST['Name']; 
    $Email = $_POST['Email']; 
    $Message = $_POST['Message']; 
    $complete = 0; 
    $email_to = "[email protected]"; 
    $email_subject = "Website Contact"; 

    //check all forms are filled in correctly 

    $email_exp = '/^[A-Za-z0-9._%-][email protected][A-Za-z0-9.-]+\.[A-Za-z]{2,4}$/'; 
    if(preg_match($email_exp,$Email)) { 
    $complete++; 
    } 
    $string_exp = "/^[A-Za-z .'-]+$/"; 
    if(preg_match($string_exp,$Name)) { 
    $complete++; 
    } 
    if(strlen($Message) > 20) { 
    $complete++; 
    } 
    //send email if $complete = 4 
    if ($complete == 3){ 
     if (get_magic_quotes_gpc()) { 
      $Message = stripslashes($Message); 
     } 
    $Message = $Message . "\n\n" . "From " . $Name; 
    $headers = 'From: '.$Email."\r\n". 
'Reply-To: '.$Email."\r\n" . 
'X-Mailer: PHP/' . phpversion(); 
@mail($email_to, $email_subject, $Message, $headers); 
echo '<script> 
    alert("Thank you for contacting me. I will be in touch shortly"); 
    top.location="index.php"; 
    </script>'; 
} 
else { 
    echo '<script> 
      alert("The form you submitted is invalid. Please ensure the following: \n You have provided a valid email address. \n Your phone number is entered correctly. \n The message box contains at least 20 characters.") 
      history.go(-1) 
      </script>'; 
    } 
} 

?> 

所以我的问题是,当表单提交到PHP文件时,浏览器加载PHP文件,运行代码并返回结果(这不是一个真正的问题,但它是我不想要的)然后由java来显示警报并返回一个(在我的代码中)。有没有办法让它在后台运行代码,以便表单运行php文件而不必去(如果有意义的话)并在相同的窗口中返回结果。我显然四处看了看,发现了很多关于AJAX的东西,但是我并没有真正理解它,也无法让它为我工作。

做这件事的原因有点复杂,但会让事情变得容易很多,只要用户友好适用于我的网站,并且看起来更干净(进入空白页面并显示警告看起来不是很好好)。

预先感谢任何帮助,您可以给我:)

回答

0
$('.Submitbtn').click(function(e) { 
    e.preventDefault(); 
    // do some form validation here 
    if form is valid { // from validation above 
     var formData = $('#email_form').serialize(); 
     $.post('send_email.php',{data:formData}); 
    } else { 
     alert('Form no good - fix it!'); 
     return false; 
    } 
}); 

这里的东西你可以开始。这是非常基本的,但为开始AJAX冒险提供了必要的基础。

50 Excellent AJAX Tutorials

+0

麻烦的是,我真的不明白发生了什么那里,我更愿意理解的代码之前,我实现它,这样,如果/当我需要我可以对其进行编辑。我会尝试,但显然:) –

+0

我需要在if语句中放置什么? 'if if(form is valid)' –

+0

那么,你是在问一个人写你需要的AJAX代码,然后向你详细解释它?这就是教程网站的用途。 – DevlshOne

相关问题