Я пытаюсь добавить другое поле ввода в мою контактную форму на своем веб-сайте. Форма по умолчанию - имя, адрес электронной почты и поле сообщения. Я также пытаюсь добавить поле темы.Поле в почтовой форме php не регистрирует ввод пользователя
Проблема в том, что он не записывает никаких данных в поле темы. Поэтому, когда я получаю письмо, все поля по умолчанию правильно записывают вход, но мое добавление поля темы пуст.
Ниже приведен соответствующий HTML, JavaScript (для AJAX) и код PHP:
//Listens for Submit button, prevents page refresh and calls on submitForm()
$("#contactForm").submit(function(event) {
// cancels the form submission
event.preventDefault();
submitForm();
});
//Grabs form input, and starts an ajax object
function submitForm() {
// Initiate Variables With Form Content
var name = $("#name").val();
var email = $("#email").val();
var messagesubject = $("#messagesubject").val();
var message = $("#message").val();
//I have added "&messagesubject=" + messagesubject to the data: to get input in the subject field
$.ajax({
type: "POST",
url: "php/form-process.php",
data: "name=" + name + "&email=" + email + "&messagesubject=" + messagesubject + "&message=" + message,
success: function(text) {
if (text == "success") {
formSuccess();
}
}
});
}
function formSuccess() {
$("#msgSubmit").removeClass("hidden");
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.11.2/js/bootstrap-select.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" rel="stylesheet" />
<link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.12.1/css/bootstrap-select.min.css" rel="stylesheet" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="col-lg-6 col-xs-12">
<div class="contact-form">
<h3>Send us a message. We're here to help!</h3>
<form role="form" id="contactForm">
<div class="row">
<div class="form-group col-sm-6">
<label for="name" class="h4">Name</label>
<input type="text" class="form-control" id="name" placeholder="Enter name" required>
</div>
<div class="form-group col-sm-6">
<label for="email" class="h4">Email</label>
<input type="email" class="form-control" id="email" placeholder="Enter email" required>
</div>
</div>
<div class="form-group">
<label for="messagesubject" class="h4 ">Subject</label>
<input type="messagesubject" class="form-control" placeholder="Enter Subject" required>
</div>
<div class="form-group">
<label for="message" class="h4 ">Message</label>
<textarea id="message" class="form-control" rows="5" placeholder="Enter your message" required></textarea>
</div>
<button type="submit" id="form-submit" class="btn btn-success btn-lg pull-right ">Submit</button>
<div id="msgSubmit" class="h3 text-center hidden">Message Submitted!</div>
</form>
</div>
</div>
А вот PHP код для обработки phpmail и получите это сообщение на мой адрес электронной почты. Не удалось включить его в фрагмент, но это довольно простая настройка phpmail.
<?php
$name = $_POST["name"];
$email = $_POST["email"];
$MessageSubject = $_POST["MessageSubject"];
$message = $_POST["message"];
$EmailTo = "[email protected]";
$Subject = "$messagesubject from $name";
// prepare email body text
$Body .= "Name: ";
$Body .= $name;
$Body .= "\n";
$Body .= "Email: ";
$Body .= $email;
$Body .= "\n";
$Body .= "Subject: ";
$Body .= $messagesubject;
$Body .= "\n";
$Body .= "Message: ";
$Body .= $message;
$Body .= "\n";
// send email
$success = mail($EmailTo, $Subject, $Body, .$MessageSubject "From:".$email);
// redirect to success page
if ($success){
echo "success";
}else{
echo "invalid";
}
?>
doh! Спасибо!! – raimond
Добро пожаловать. Удачи вам в этом. – Robbie