当我点击发送时,我的 PHP/JS 联系表单没有做任何事情

My PHP/JS contact form is not doing anything when I click send

提问人:Tavas 提问时间:11/5/2023 最后编辑:Tavas 更新时间:11/5/2023 访问量:72

问:

我通过 Github 页面创建了一个简单的投资组合网站,但我无法让联系表正常工作。您可以在此处查看联系表格

当我单击发送时,什么也没发生,我无法弄清楚为什么代码没有连接,因为一开始一切似乎都在模板中。

下面是 JS 代码:

    $("#contactform").submit(function () {
        var a = $(this).attr("action");
        $("#message").slideUp(750, function () {
            $("#message").hide();
            $("#submit").attr("disabled", "disabled");
            $.post(a, {
                name: $("#name").val(),
                email: $("#email").val(),
                comments: $("#comments").val()
            }, function (a) {
                document.getElementById("message").innerHTML = a;
                $("#message").slideDown("slow");
                $("#submit").removeAttr("disabled");
                if (null != a.match("success")) $("#contactform").slideDown("slow");
            });
        });
        return false;
    });
    $("#contactform input, #contactform textarea").keyup(function () {
        $("#message").slideUp(1500);
    });
    $(".mob_filter-btn").on("click", function () {
        $(".inline-filters-wrap .gallery-filters").fadeToggle(400);

    });

下面是 HTML:

                        <div id="contact-form" class="fl-wrap">
                            <div id="message"></div>
                            <form  class="custom-form" action="php/contact.php" name="contactform" id="contactform">
                                <fieldset>
                                    <input type="text" name="name" id="name" placeholder="Your name *" value="">
                                    <input type="text"  name="email" id="email" placeholder="Your email *" value="">
                                    <textarea name="comments"  id="comments" cols="40" rows="3" placeholder="Your message:"></textarea>
                                    <button class="btn float-btn flat-btn color-bg" id="submit" type="submit">Send </button>
                                </fieldset>
                            </form>
                        </div>
                    </div>

这是 PHP:

<?php

if(!$_POST) exit;

// Email address verification, do not edit.
function isEmail($email) {
    return(preg_match("/^[-_.[:alnum:]]+@((([[:alnum:]]|[[:alnum:]][[:alnum:]-]*[[:alnum:]])\.)+(ad|ae|aero|af|ag|ai|al|am|an|ao|aq|ar|arpa|as|at|au|aw|az|ba|bb|bd|be|bf|bg|bh|bi|biz|bj|bm|bn|bo|br|bs|bt|bv|bw|by|bz|ca|cc|cd|cf|cg|ch|ci|ck|cl|cm|cn|co|com|coop|cr|cs|cu|cv|cx|cy|cz|de|dj|dk|dm|do|dz|ec|edu|ee|eg|eh|er|es|et|eu|fi|fj|fk|fm|fo|fr|ga|gb|gd|ge|gf|gh|gi|gl|gm|gn|gov|gp|gq|gr|gs|gt|gu|gw|gy|hk|hm|hn|hr|ht|hu|id|ie|il|in|info|int|io|iq|ir|is|it|jm|jo|jp|ke|kg|kh|ki|km|kn|kp|kr|kw|ky|kz|la|lb|lc|li|lk|lr|ls|lt|lu|lv|ly|ma|mc|md|me|mg|mh|mil|mk|ml|mm|mn|mo|mp|mq|mr|ms|mt|mu|museum|mv|mw|mx|my|mz|na|name|nc|ne|net|nf|ng|ni|nl|no|np|nr|nt|nu|nz|om|org|pa|pe|pf|pg|ph|pk|pl|pm|pn|pr|pro|ps|pt|pw|py|qa|re|ro|ru|rw|sa|sb|sc|sd|se|sg|sh|si|sj|sk|sl|sm|sn|so|sr|st|su|sv|sy|sz|tc|td|tf|tg|th|tj|tk|tm|tn|to|tp|tr|tt|tv|tw|tz|ua|ug|uk|um|us|uy|uz|va|vc|ve|vg|vi|vn|vu|wf|ws|ye|yt|yu|za|zm|zw)$|(([0-9][0-9]?|[0-1][0-9][0-9]|[2][0-4][0-9]|[2][5][0-5])\.){3}([0-9][0-9]?|[0-1][0-9][0-9]|[2][0-4][0-9]|[2][5][0-5]))$/i",$email));
}

if (!defined("PHP_EOL")) define("PHP_EOL", "\r\n");

$name     = $_POST['name'];
$email    = $_POST['email'];
$comments = $_POST['comments'];


if(trim($name) == '') {
    echo '<div class="error_message">Enter your name.</div>';
    exit();
} else if(trim($email) == '') {
    echo '<div class="error_message">Enter a valid email address.</div>';
    exit();
} else if(!isEmail($email)) {
    echo '<div class="error_message">You have entered an invalid e-mail address. Please try again.</div>';
    exit();
} else if(trim($comments) == '') {
    echo '<div class="error_message">Enter your message.</div>';
    exit();
} 

if(get_magic_quotes_gpc()) {
    $comments = stripslashes($comments);
}


// Configuration option.
// Enter the email address that you want to emails to be sent to.
// Example $address = "[email protected]";

//$address = "[email protected]";
$address = "[email protected]";


// Configuration option.
// i.e. The standard subject will appear as, "You've been contacted by John Doe."

// Example, $e_subject = '$name . ' has contacted you via Your Website.';

$e_subject = 'You\'ve been contacted by ' . $name . '.';


// Configuration option.
// You can change this if you feel that you need to.
// Developers, you may wish to add more fields to the form, in which case you must be sure to add them here.

$e_body = "You have been contacted by: $name" . PHP_EOL . PHP_EOL;
$e_reply = "E-mail: $email\r\nPhone: $phone";
$e_content = "Message:\r\n$comments" . PHP_EOL . PHP_EOL;


$msg = wordwrap( $e_body . $e_content . $e_reply, 70 );

$headers = "From: $email" . PHP_EOL;
$headers .= "Reply-To: $email" . PHP_EOL;
$headers .= "MIME-Version: 1.0" . PHP_EOL;
$headers .= "Content-type: text/plain; charset=utf-8" . PHP_EOL;
$headers .= "Content-Transfer-Encoding: quoted-printable" . PHP_EOL;

if(mail($address, $e_subject, $msg, $headers)) {

    // Email has sent successfully, echo a success page.

    echo "<fieldset>";
    echo "<div id='success_page'>";
    echo "<h3>Email sent successfully.</h3>";
    echo "<p>Thank you <strong>$name</strong>. Your message has been submitted to us.</p>";
    echo "</div>";
    echo "</fieldset>";

} else {

    echo 'ERROR!';

}

谁能引导我朝着正确的方向前进,因为我甚至不知道该去哪里看?我尝试在网上搜索,但找不到有关代码如何工作的解释。我想(至少是广义上)每段代码的作用,但无法理解问题出在哪里。感谢您的帮助。

JavaScript PHP HTML 联系表单

评论

1赞 Eriks Klotins 11/5/2023
您的 HTML 表单没有提交按钮。geeksforgeeks.org/......
0赞 Ken Lee 11/5/2023
请添加到按钮type=submit
1赞 ADyson 11/5/2023
由于该按钮不在表单内,因此它不会触发表单的提交事件。当它出现时,你需要阻止默认的回发行为 - 查看 jquery 的 preventDefault 函数。或者,您可以直接处理按钮的“单击”事件,而忽略表单。
0赞 Tavas 11/5/2023
我尝试将 type=submit 添加到按钮,但它仍然不起作用。它是否需要是<input type=submit类型的按钮才能使其工作?
1赞 ADyson 11/6/2023
这些都不是新东西,已经有数以百万计的教程和示例,您可以遵循这些教程和示例,以便知道该怎么做。例如:stackoverflow.com/questions/1960240/jquery-ajax-submit-form

答: 暂无答案