PHP联系人表单状态更新在DIV


PHP Contact Form Status Update in DIV

听起来像一个奇怪的问题,但这是我的。php在末尾有一个代码片段,说明成功或失败会使一个白屏幕显示这个,我真的希望它在同一页面的提交按钮下面弹出,而不是重定向整个页面。

我想我可以把它指向一个空的<div> ?

mail.php:

<?php
    $name = $_POST['name'];
    $email = $_POST['email'];
    $phone = $_POST['phone'];
    $message = $_POST['message'];
    $formcontent=" From: $name 'n Phone: $phone 'n Message: $message";
    $recipient = "art@jamisonsigns.com";
    $subject = "Web Contact Form";
    $mailheader = "From: $email 'r'n";
    mail($recipient, $subject, $formcontent, $mailheader) or die("Error!");
    echo "Thank You!" . " -" . "<a href='index.html' style='text-decoration:none;color:#ff0099;'> Return Home</a>";
?>
在我的网站上有一个简单的HTML表单,如下所示:
<form class="contact-form" form action="mail.php" method="POST">
      <fieldset>
           <input type="text" class="name" id="name" placeholder="Name...">
      </fieldset> 
      <fieldset>
           <input type="email" class="email" id="email" placeholder="Email...">
      </fieldset> 
      <fieldset>
           <input type="text" class="phone" id="phone" placeholder="Phone...">
      </fieldset>
      <fieldset>
           <textarea name="message" id="message" cols="30" rows="4" placeholder="Message.."></textarea>
      </fieldset>
      <fieldset>
           <input type="submit" class="button" id="button" value="Send Message">
      </fieldset>
 </form>

您需要使用Ajax提交表单。如果成功,则在html中插入消息。

$('#button').click(function(event) {
event.preventDefault();
var formdata = $('#formID').serializeArray();
var url = '/urltopost.php';
$.ajax( 
{
    url : url,
    type: "POST",
    data: formdata,
    success:function(data, textStatus, jqXHR) 
    {
        //data: return data from server
        console.log("STATUS:" + textStatus + " | jqXHR:" + jqXHR + " | data:" + data);
    },
    error: function(jqXHR, textStatus, errorThrown) 
    {
        //if fails      
        alert("ERROR:" + " -> " +errorThrown);
    }
});

});