提交表格后如何留在页面上

时间:2017-06-11 19:41:21

标签: javascript php html ajax forms

我已经找了好几天试图找到我的具体问题的答案,但我无法这样做。请帮忙。

我的网站上有一个表单,一旦点击,就应该发送一封电子邮件。我希望在停留在同一页面上并将div从表单更改为图像时执行此操作。

这是我设法从互联网上清除的代码。

如果你能以最多的Barney风格,请提供建议 提前感谢任何可能提供帮助的人。

jQuery(document).ready(function(){

    jQuery('.contact').submit( function() {

$.ajax({
      type: "POST",
      url: "contact-form-handler.php",
      data: dataString,
      success: function() {
        $('#contact_form').html("<div id='message'></div>");
        $('#message').html("<img src='thankyou.jpg' style='width:100%'/>")
        .append("<p>We will be in touch soon.</p>")
        .hide();
        });
      }
    });
        return false;

});
<form method="post" action="" name="contact" id="contact" class="w3-container w3-light-grey w3-margin">

  <div class="w3-row w3-section">
    <div class="w3-col" style="width:50px"><i class="w3-xxlarge fa fa-user"></i></div>
    <div class="w3-rest">
      <input class="w3-input w3-border" required name="name" id="name" type="text" placeholder="Name">

    </div>
  </div>

  <div class="w3-row w3-section">
    <div class="w3-col" style="width:50px"><i class="w3-xxlarge fa fa-envelope-o"></i></div>
    <div class="w3-rest">
      <input class="w3-input w3-border" required name="email" id="email" type="text" placeholder="Email">

    </div>
  </div>

  <div class="w3-row w3-section">
    <div class="w3-col" style="width:50px"><i class="w3-xxlarge fa fa-pencil"></i></div>
    <div class="w3-rest">
      <input id="message" class="w3-input w3-border" required name="message" type="text" placeholder="Message">

    </div>
  </div>

  <p class="w3-center">
    <input type="submit" name="submit" class="button w3-section w3-black w3-ripple" id="submit_btn" value="Send" />
  </p>


</form>

`

<?php
$errors = '';
$myemail = 'jerry@sitesbyjc.com';//<-----Put Your email address here.
if(empty($_POST['name'])  || 
   empty($_POST['email']) || 
   empty($_POST['message']))
{
    $errors .= "\n Error: all fields are required";
}

$name = $_POST['name']; 
$email_address = $_POST['email']; 
$message = $_POST['message']; 

if (!preg_match(
"/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$/i", 
$email_address))
{
    $errors .= "\n Error: Invalid email address";
}

if( empty($errors))
{
	$to = $myemail; 
	$email_subject = "Contact form submission: $name";
	$email_body = "You have received a new message. ".
	" Here are the details:\n Name: $name \n Email: $email_address \n Message: \n $message"; 
	
	$headers = "From: $myemail\n"; 
	$headers .= "Reply-To: $email_address";
	
	mail($to,$email_subject,$email_body,$headers);
   
    
} 
?>

3 个答案:

答案 0 :(得分:1)

<form>将其作为默认行为,将用户重定向到提交时的网址。从action属性获取的URL。

为了防止这种重定向,你必须告诉浏览器:&#34;不要重定向&#34;。

简短: e.preventDefault()

长:在提交回调中,您的函数会获取参数。只需将其命名为:e。这是一个对象,它有一个函数preventDefault。此功能可防止默认行为:重定向。在回调函数的第一行调用。

答案 1 :(得分:0)

如果我理解你的问题,你需要在调用AJAX时使用preventDefault()为了阻止提交(默认情况下),所以你可以这样做:

jQuery(document).ready(function(){
    jQuery('.contact').submit( function($e) {

        $e.preventDefault();
        $.ajax({
            type: "POST",
            url: "contact-form-handler.php",
            data: dataString,
            success: function() {
                $('#contact_form').html("<div id='message'></div>");
                $('#message').html("<img src='thankyou.jpg' style='width:100%'/>")
                .append("<p>We will be in touch soon.</p>")
                .hide();
            });
        }
    });
    return false;

});

详细了解preventDefault()以及MDN上的defaultPrevented

答案 2 :(得分:0)

您可以将事件处理程序附加到提交按钮并将提交按钮更改为一个简单的按钮,这样在单击时不会提交表单。按钮代码可以更改为:

<input type="button" name="submit" class="button w3-section w3-black w3-ripple" id="submit_btn" value="Send" />

事件处理代码可以更改为:

jQuery('#submit_btn').submit( function() {

};