Wordpress电子邮件表格

时间:2013-03-21 08:02:18

标签: wordpress email

Wordpress电子邮件表单

大家好

我一直在很多网站上使用这种电子邮件表格,而且它总能奏效。

我试过在Wordpress网站上使用它,但它不会

有什么明显的理由说明这种方法在Wordpress网站中不起作用。

我需要一个不会重新加载联系页面的电子邮件表单,因为表单位于底部。

HTML

    <form action="#" id="contact_form">
         <input type="text" id="name" placeholder="Name:">
         <input type="text" id="email" placeholder="Email:">
         <textarea id="message" rows="8" cols="40" placeholder="Message:"></textarea>
                <input type="submit" id="submit"/>
                <div id="status">
           <p></p>
         </div>
     </form>

Jquery的

      $('#submit').click(function(){    
        //
        var nameVal = $('#contact_form #name').val();
        var emailVal = $('#contact_form #email').val();
        var messageVal = $('#contact_form #message').val();
        //
        $.post('/contact_form.php', {name: nameVal, email: emailVal, message: messageVal}, function(data){
            $("#status p").html(data);
            $("#status p").show().fadeOut(3500);
            if(data.indexOf('Thank You')==0) {document.forms[0].reset();}
        });
      })

PHP

        $errors = array();
        $required_fields = array('name','email','message');
        foreach($required_fields as $fieldname){
            if(!isset($_POST[$fieldname]) || empty($_POST[$fieldname])){
                $errors[] = $fieldname;
            }
        }

        if(empty($errors)){
            $name_field = Trim(stripslashes($_POST['name']));
            $name = explode(' ', $name_field);
            $firstname = ucfirst($name[0]);
            $email_field = Trim(stripslashes($_POST['email']));
            $message = Trim(stripslashes($_POST['message']));
            //
            $to = "info@ttmt.org.uk";
            $subject = "Email from Website";
            $body = "From: $name_field\n E-Mail: $email_field\n Message:\n $message";
            //
            mail($to, $subject, $body);
            echo "Thank You $firstname";
        }else{
            echo "Please complete all.";
        }

---更新---

我现在有一部分工作了。

部分问题是jquery无法找到php。

我在wp-conntent中创建了一个'code'文件夹并将php放在那里,jquery看起来像这样。

    $j.post('wp-content/code/contactEngine.php', { theName:nameVal, theEmail:emailVal, theMessage:messageVal }, function(data){

现在我从php文件中获取返回的数据,但不发送电子邮件。

这不适用于WP

    mail($to, $subject, $body);

1 个答案:

答案 0 :(得分:2)

你不能在Wordpress中使用$ _POST ['name']。使用其他命名输入字段将解决您的问题,最终您可以使用'Contact Form 7'Wordpress-plugin获得更好的用户体验: - )