javascript - 为什么表单提交消息显示我的 index.html 文件中的所有字符?

标签 javascript php jquery html css

当我的消息被提交时,它会转到我的电子邮件地址并且工作正常,但消息成功通知不会显示“您的消息已成功发送。”,而是显示我的索引文件中的所有代码行。

我认为这与style="display: none"有关。

知道如何显示“您的消息已发送”消息吗?

index.html

            <div class="col-lg-5 mx-auto">
              <div class="contact-form">
                <div class="container"> 
                    <form class="contact-form" method="post" action="mail.php">    

                    <!-- form message -->
                        <div class="row">
                            <div class="col-lg-12">
                              <div class="alert alert-success contact__msg" style="display: none" role="alert">
                              Your message was sent successfully.
                                </div>
                                </div>
                            </div>
                    <!-- end message -->

                    <!-- form element -->
                        <div class="form-group">
                            <label><strong>Name</strong></label>
                              <input name="name" type="text" class="form-control" placeholder="Enter Name" required>
                        </div>
                        <div class="form-group">
                            <label><strong>Email</strong></label>
                              <input name="email" type="email" class="form-control" placeholder="Enter Email" required>
                        </div>
                        <div class="form-group">
                            <label><strong>Message</strong></label>
                              <textarea name="message" class="form-control" rows="3" placeholder="Enter Message" required></textarea>
                        </div>
                        <button name="submit" type="submit" class="btn btn-default"><span class="fa fa-paper-plane"></button></span>
                    <!-- end form element -->
                    </form>
                        </div>
                </div>

mail.php

<?php

    if ($_SERVER["REQUEST_METHOD"] == "POST") {

        # FIX: Replace this email with recipient email
        $mail_to = "*myemail*@gmail.com";

        # Sender Data
        $name = str_replace(array("\r","\n"),array(" "," ") , strip_tags(trim($_POST["name"])));
        $email = filter_var(trim($_POST["email"]), FILTER_SANITIZE_EMAIL);
        $message = trim($_POST["message"]);

        if ( empty($name) OR !filter_var($email, FILTER_VALIDATE_EMAIL) OR empty($subject) OR empty($message)) {
            # Set a 400 (bad request) response code and exit.
            http_response_code(400);
            echo "Please complete the form and try again.";
            exit;
        }

        # Mail Content
        $content = "Name: $name\n";
        $content .= "Email: $email\n\n";
        $content .= "Message:\n$message\n";

        # email headers.
        $headers = "From: $name <$email>";

        # Send the email.
        $success = mail($mail_to, $subject, $content, $headers);
        if ($success) {
            # Set a 200 (okay) response code.
            http_response_code(200);
            echo "Thank You! Your message has been sent.";
        } else {
            # Set a 500 (internal server error) response code.
            http_response_code(500);
            echo "Oops! Something went wrong, we couldn't send your message.";
        }

    } else {
        # Not a POST request, set a 403 (forbidden) response code.
        http_response_code(403);
        echo "There was a problem with your submission, please try again.";
    }

?>

main.js

(function ($) {
    'use strict';

    var form = $('.contact-form'),
        message = $('.contact__msg'),
        form_data;

    // Success function
    function done_func(response) {
        message.fadeIn().removeClass('alert-danger').addClass('alert-success');
        message.text(response);
        setTimeout(function () {
            message.fadeOut();
        }, 100000);
        form.find('input:not([type="submit"]), textarea').val('');
    }

    // fail function
    function fail_func(data) {
        message.fadeIn().removeClass('alert-success').addClass('alert-success');
        message.text(data.responseText);
        setTimeout(function () {
            message.fadeOut();
        }, 100000);
    }

    form.submit(function (e) {
        e.preventDefault();
        form_data = $(this).serialize();
        $.ajax({
            type: 'POST',
            url: form.attr('action'),
            data: form_data
        })
        .done(done_func)
        .fail(fail_func);
    });

})(jQuery);

最佳答案

检查您指定响应但不显示文本的成功函数。 例如:message.text(response.??);

不包括包含来自后端脚本的消息的字段,所以我猜问题出在这里。 display:none 不是问题...

关于javascript - 为什么表单提交消息显示我的 index.html 文件中的所有字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51799242/

相关文章:

javascript - 在ngrepeat中对行进行分组

php - 从一个表中获取数据到另一个表

PHP 如何在处理另一个表单后保持在同一页面?

javascript - 单击单选按钮时触发事件

javascript - jQuery:是否可以将字段/方法附加到 jQuery 包装器对象?

javascript - 从隐藏的代码中过滤 TextBox 的 KeyPress 事件上的 GridView

javascript - Angular 6 - 错误 DOMException : Failed to execute 'setAttribute' on 'Element' :

javascript - 在for循环Angular2 Django中获取多个可观察请求

javascript - Javascript 的 getElementById 的使用

php - sUrl 和 fUrl 应该是什么 - PayU Money iOS 集成