2016-12-14 4 views
-2

Я пытаюсь добавить другое поле ввода в мою контактную форму на своем веб-сайте. Форма по умолчанию - имя, адрес электронной почты и поле сообщения. Я также пытаюсь добавить поле темы.Поле в почтовой форме 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"; 
} 

?> 

ответ

2

id="messagesubject" отсутствует в поле ввода.

<div class="form-group"> 
    <label for="messagesubject" class="h4 ">Subject</label> 
    <input type="messagesubject" class="form-control" id="messagesubject" placeholder="Enter Subject" required> 
    </div> 
+0

doh! Спасибо!! – raimond

+0

Добро пожаловать. Удачи вам в этом. – Robbie

 Смежные вопросы

  • Нет связанных вопросов^_^