douzhui8531 2018-07-13 14:06
浏览 79
已采纳

Bootstrap模式中的WordPress自定义联系表单未显示验证和提交响应

For my WordPress I am using Bootstrap and built a Custom Contact form with below HTML (followed this tutorial: https://premium.wpmudev.org/blog/how-to-build-your-own-wordpress-contact-form-and-why/).

<form id="contact-form" action="<?php echo get_site_url(); ?>" method="post">

<div class="modal-body">
    <?php echo $response; ?>
    <div class="form-group">
        <input class="form-control my-2" type="text" name="message_name" size="50" placeholder="Your full name" value="<?php echo esc_attr($_POST['message_name']); ?>">
        <input class="form-control my-2" type="email" name="message_email" size="50" placeholder="Email address" value="<?php echo esc_attr($_POST['message_email']); ?>">
        <input class="form-control my-2" type="tel" name="message_tel" size="50" placeholder="Country code, Phone number" value="<?php echo esc_attr($_POST['message_tel']); ?>">
        <textarea class="form-control my-2" name="message_text" rows="2" placeholder="Your message" value="<?php echo esc_attr($_POST['message_text']); ?>"></textarea>
        <input  class="form-control my-2" type="text" name="message_human" placeholder="Human check: Enter 2">
        <input type="hidden" name="message_url" value="<?php the_permalink(); ?>">
        <input type="hidden" name="message_page" value="<?php the_title(); ?>">
    </div>
</div>
<div class="modal-footer">
    <input type="hidden" name="submitted" value="1">
    <button type="submit" value="Submit" class="btn btn-search form-control">Send Enquiry</button>
</div>

Below the function to validate the Forms & show responses while Form submission:

//response generation function
$response = "";

//function to generate response
function contact_g_form_response($type, $message) {

global $response;

if ($type == "success") {
    $response = "<div class='message-success text-center'>{$message}</div>";
} else {
    $response = "<div class='message-error text-center'>{$message}</div>";
}
}

//response messages
$not_human = "Enter current year in numbers.";
$missing_content = "Missing something.";
$email_invalid = "Check your Email address.";
$message_unsent = "Message was not sent. Try Again.";
$message_sent = "Thanks! We got your enquiry.";

//user posted variables
$name = $_POST['message_name'];
$email = $_POST['message_email'];
$fromEmail = $name . '<' . $email . '>';
$tel = $_POST['message_tel'];
$text = $_POST['message_text'];
$url = $_POST['message_url'];
$page = $_POST['message_page'];
$human = $_POST['message_human'];


//php mailer variables
$to = get_option('admin_email');
$subject = '[General Enquiry] ' . $name . ' | Phone Number:' . $tel;
$headers = 'From: ' . $fromEmail . "
" .
    'Reply-To: ' . $email . "
";

$message = '<html><body><h1>New general enquiry from ' . $name . '!</h1>'
    . '<p>Email: ' . $email . '</p>'
    . '<p>Phone Number: ' . $tel . '</P>'
    . '<p>Inquiry: ' . $text . '</P>'
    . '<p>From page: <b>' . $page . '</b></P>'
    . '<p>Page URL: ' . $url . '</p>'
    . '</body></html>';

if (!$human == 0) {
if ($human != 2) {
    contact_g_form_response("error", $not_human); //not human!
} else {

    //validate email
    if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
        contact_g_form_response("error", $email_invalid);
    } else { //email is valid
        //validate presence of name, phone number
        if (empty($name) || empty($tel)) {
            contact_g_form_response("error", $missing_content);
        } else { //ready to go!
            $sent = wp_mail($to, $subject, $message, implode("
", $headers)); //mail to admin - striptags removing formatting
            // $sent2 = wp_mail($email, $subject, $body, $headers); //mail to visitor
            // if ($sent || $sent2) {
            if ($sent) {
                contact_g_form_response("success", $message_sent); //message sent!
            } else {
                contact_g_form_response("error", $message_unsent); //message wasn't sent
            }
        }
    }
}
} else if ($_POST['submitted']) {
contact_g_form_response("error", $missing_content);
}

Although the Form is being successfully submitted, no response / validation messages are shown as per contact_g_form_responsefunction and after the Form submission, it is being redirected to a random WordPress post.

  • 写回答

1条回答 默认 最新

  • douguachan2879 2018-07-17 05:34
    关注

    You Just Need To replace this:

    <form id="contact-form" action="<?php echo get_site_url();?>" method="post">
    

    With This:

    <form id="contact-form" method="post">
    

    Because You are displaying the error on the same page but on click of the submit button the action is taking you to a specific url and that's the reason the validations are not shown.

    And This:

    if ($type == "success") {
    $response = "<div class='message-success text-center'>{$message}</div>";
    } else {
    $response = "<div class='message-error text-center'>{$message}</div>";
    }
    

    With This also:

    if ($type == "success") {
    $response =  $message;
    echo $response;
    } else {
    $response =  $message;
    echo $response;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?