我使用以下代码使用 php 和 ajax 构建联系表单:
.HTML:
<head>
<script src="js/app.js"></script>
</head>
<body>
<form id="ajax-contact" method="post" action="php/mailer.php">
<input type="text" id="name" name="name" required>
<input type="text" id="email" name="email" required>
<textarea id="message" name="message" required></textarea>
<input class="submit" type="submit" value="Send">
</form>
<div id="form-messages">
</div>
</body>
阿贾克斯:
$(function() {
var form = $('#ajax-contact');
var formMessages = $('#form-messages');
});
$(form).submit(function(event) {
event.preventDefault();
});
var formData = $(form).serialize();
$.ajax({
type: 'POST',
url: $(form).attr('action'),
data: formData
}).done(function(response) {
$(formMessages).removeClass('error');
$(formMessages).addClass('success');
$(formMessages).text(response);
$('#name').val('');
$('#email').val('');
$('#message').val('');
}).fail(function(data) {
$(formMessages).removeClass('success');
$(formMessages).addClass('error');
if (data.responseText !== '') {
$(formMessages).text(data.responseText);
} else {
$(formMessages).text('Oops! An error occured and your message could not be sent.');
}
});
邮件:
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$name = strip_tags(trim($_POST["name"]));
$name = str_replace(array("'r","'n"),array(" "," "),$name);
$email = filter_var(trim($_POST["email"]), FILTER_SANITIZE_EMAIL);
$message = trim($_POST["message"]);
if ( empty($name) OR empty($message) OR !filter_var($email, FILTER_VALIDATE_EMAIL)) {
http_response_code(400);
echo "Oops! There was a problem with your submission. Please complete the form and try again.";
exit;
}
$recipient = "mailreceiver@example.com";
$subject = "New contact from $name";
$email_content = "Name: $name'n";
$email_content .= "Email: $email'n'n";
$email_content .= "Message:'n$message'n";
$email_headers = "From: $name <$email>";
if (mail($recipient, $subject, $email_content, $email_headers)) {
http_response_code(200);
echo "Thank You! Your message has been sent.";
} else {
http_response_code(500);
echo "Oops! Something went wrong and we couldn't send your message.";
}
} else {
http_response_code(403);
echo "There was a problem with your submission, please try again.";
}
?>
在 Ajax 的操作中,我加载 php 邮件程序文件以将邮件发送到我当前的邮件地址,但我想在后台执行此操作,因为我使用的是 ajax...我想留在表单的 html 页面上,而不重定向到该 php 页面以发送该邮件,并且只在div:form-messages 中显示成功或失败。
我在这里错过了什么?
尝试这样做:
将您的输入提交按钮与类"提交"绑定以使用 ajax 提交表单。您可以使用 $(form)[0].reset() 重置表单;清晰的输入值
$('.submit').click(function() { //<-- changed/new
var form = $('#ajax-contact');
var formMessages = $('#form-messages');
var formData = $(form).serialize();
$.ajax({
type: 'POST',
url: $(form).attr('action'),
data: formData
}).done(function(response) {
$(formMessages).removeClass('error');
$(formMessages).addClass('success');
$(formMessages).text(response);
$(form)[0].reset(); //<-- changed/new
}).fail(function(data) {
$(formMessages).removeClass('success');
$(formMessages).addClass('error');
if (data.responseText !== '') {
$(formMessages).text(data.responseText);
} else {
$(formMessages).text('Oops! An error occured and your message could not be sent.');
}
});
});
尝试这样的东西:
$('.submit').click(function(event) {
//use this to dont submit the form
event.preventDefault();
//your ajax stuff
$.ajax....
//if you dont want to use the preventDefault function just
return false;
}
尝试删除action="php/mailer"
并执行以下操作
function sendEmail(message){
var data = new XMLHttpRequest();
data.open("POST","php/mailer.php");
data.onreadystatechange = function(){
if(data.readyState === 4 && data.status === 200){
document.getElementById('results').innerHTML = "Email sent";
}
}
data.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
data.send("message=" + message);
}
您可以在"提交"按钮中调用该函数。