【发布时间】:2015-11-28 00:46:49
【问题描述】:
我有一个发送电子邮件的基本表格。它正在发送电子邮件,但不传递表单中的数据。我是否缺少允许数据发布的内容?
发送电子邮件的 HTML 表单:
<form id="main-contact-form" class="contact-form" name="contact-form" method="post" action="sendemail.php" role="form">
<div class="row">
<div class="col-sm-5">
<div class="form-group">
<input name="name" type="text" class="form-control" required="required" placeholder="Name">
</div>
<div class="form-group">
<input name="email" type="text" class="form-control" required="required" placeholder="Email address">
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary btn-lg">Send Message</button>
</div>
</div>
<div class="col-sm-7">
<textarea name="message" required="required" class="form-control" rows="8" placeholder="Message"></textarea>
</div>
</div>
</form>
sendemail.php 中的 PHP 代码
<?php
header('Content-type: application/json');
$status = array(
'type'=>'success',
'message'=>'Email sent!'
);
$name = @trim(stripslashes($_POST['name']));
$email = @trim(stripslashes($_POST['email']));
$subject = "Example Contact";
$message = @trim(stripslashes($_POST['message']));
$email_from = $email;
$email_to = 'admin@example.com';
$body = 'Name: ' . $name . "\n\n" . 'Email: ' . $email . "\n\n" . 'Subject: ' . $subject . "\n\n" . 'Message: ' . $message;
$success = @mail($email_to, $subject, $body, 'From: ' . $email_from);
echo json_encode($status);
die;
更新: 包含 class="contact-form" 时,js/jquery 中似乎存在问题。如果我忽略它,就会发送变量。
这是表单的 jquery 代码:
//contact form
var form = $('.contact-form');
form.submit(function () {
$this = $(this);
$.post($(this).attr('action'), function(data) {
$this.prev().text(data.message).fadeIn().delay(3000).fadeOut();
},'json');
return false;
});
以下是一些相关帖子:
PHP Blank Email
Contact form won't submit data
js deleting submitted form data
PHP script sending mails but not showing form data
Post Data is not coming
【问题讨论】:
-
它自己的表格(如最初在此处发布的)工作正常,这里有其他问题。 JS 触发器/事件阻止点击帖子?
-
做一个 var_dump('$_POST');看看你会得到什么。
-
我同意 Ivan 的观点,该表格适合我!