Formularz jQuery AJAX używający skryptu mail () wysyła e-mail, ale dane POST z formularza HTML są niezdefiniowane

Dzięki za poświęcenie czasu, chłopaki. Tworzę dość podstawowy formularz kontaktowy AJAX za pomocą jQuery. E-mail wysyła, ale po otwarciu wiadomości e-mail nie ma danych POST, więc po prostu dostaję ciągi zdefiniowane w skrypcie PHP. Na kliencie poczty elektronicznej mojego telefonu treść wiadomości e-mail dosłownie mówi „niezdefiniowany”. Próbowałem dodać różne typy danych nagłówka bezskutecznie, a także wiele odmian funkcji PHP mail ().

Jestem bardziej niż chętny do przyjęcia prostszego rozwiązania dla prostego formularza AJAX, więc z góry dziękuję za wszelkie nowe podejścia.

Oto forma:

   <section id="left">
      <label for="form_name">Name</label>
      <input name="form_name" id="form_name" type="text" >

      <label for="form_email">Email</label>
      <input name="form_email" id="form_email" type="email" >
   </section>

   <section id="right">
      <label for="form_msg">Message</label>
      <textarea name="form_msg" id="form_msg"></textarea>
      <input id="submit" class="button" name="submit" type="submit" value="Send">
   </section>

</form>

JQuery AJAX:

$(function() {
    $("#contact .button").click(function() {
        var name = $("#form_name").val();
        var email = $("#form_email").val();
        var text = $("#msg_text").val();
        var dataString = 'name='+ name + '&email=' + email + '&text=' + text;

        $.ajax({
            type: "POST",
            url: "email.php",
            data: dataString,
            success: function(){
            $('.success').fadeIn(1000);
            }
        });

        return false;
    });
});

Skrypt PHP (zewnętrzny plik „email.php”):

<?php
if($_POST){
    $name = $_POST['form_name'];
    $email = $_POST['form_email'];
    $message = $_POST['form_msg'];

//send email
    mail("[email protected]", "This is an email from:" .$email, $message);
}
?>

questionAnswers(6)

yourAnswerToTheQuestion