我正在尝试使用ajax提交用header.php编写的自定义表单,并使用提交的数据将邮件发送到特定的电子邮件地址,但在控制台中获取404错误,表单验证执行taht意味着加载了jquery文件但是在尝试调用时ajaxurl发送邮件给出了404错误。我100%确定错误是在ajax调用中或需要在function.php中发送函数来发送邮件但是无法解决它,有人可以帮我解决这个问题吗?
header.php中的表格
<form id="wp_con_form" method="post">
<ul class="form-list wp_contact_form_ul cf">
<li>
<input type="text" name="name" id="name" placeholder="Name *" class="text-field wp_con_frm_name">
</li>
<li>
<input type="text" name="phone" id="phone" placeholder="Phone *" class="text-field wp_con_frm_phone">
</li>
<li>
<input type="text" name="email" id="email" placeholder="Email *" class="text-field wp_con_frm_email">
</li>
<li>
<input type="text" name="agency" id="agency" placeholder="agency" class="text-field ">
</li>
<li class="full">
<textarea name="message" id="message" placeholder="Message *" class="text-field wp_con_frm_message"></textarea>
</li>
<li class="form-button">
<input type="submit" value="Send" id="wp_con_frm_btn" class="button" />
</li>
<div class="wp_cont_form_msg"></div>
</ul>
</form>
在function.php中调用jquery文件是
wp_enqueue_style( 'themestyle', get_template_directory_uri() . '/assets/css/style.css',false,'1.1','all' );
wp_localize_script("themestyle","the_ajax_theme", array("ajaxurl_anyName" => admin_url("admin-ajax.php")));
用于验证的Jquery文件和ajax调用
var j = jQuery.noConflict();
j(document).ready(function(){
function validateContact(){
var output = true;
j('.wp_contact_form_ul li').removeClass('wp_cont_frm_err_msg');
if(!(j(".wp_con_frm_name").val())){
j(".wp_con_frm_name").parent().addClass('wp_cont_frm_err_msg');
output = false;
}
if(!(j(".wp_con_frm_phone").val())){
j(".wp_con_frm_phone").parent().addClass('wp_cont_frm_err_msg');
output = false;
}
if(!j(".wp_con_frm_phone").val().match(/^[(]{0,1}[0-9]{3}[)]{0,1}[-\s\.]{0,1}[0-9]{3}[-\s\.]{0,1}[0-9]{4}$/))
{
j(".wp_con_frm_phone").parent().addClass('wp_cont_frm_err_msg');
output = false;
}
if(!(j(".wp_con_frm_email").val())){
j(".wp_con_frm_email").parent().addClass('wp_cont_frm_err_msg');
output = false;
}
if(!j(".wp_con_frm_email").val().match(/^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/))
{
j(".wp_con_frm_email").parent().addClass('wp_cont_frm_err_msg');
output = false;
}
if(!(j(".wp_con_frm_message").val())){
j(".wp_con_frm_message").parent().addClass('wp_cont_frm_err_msg');
output = false;
}
return output;
}
/* send contact form data to email */
function afterSubmit(getobj)
{
if(getobj.status)
{
j('#wp_con_form')[0].reset();
j('#wp_con_form .wp_cont_form_msg').html(getobj.message).slideDown().delay(5000).slideUp();
}
else
{
j('#wp_con_form .wp_cont_form_msg').html(getobj.message).slideDown().delay(5000).slideUp(5000);
}
}
j('#wp_con_frm_btn').click(function(){
var output = validateContact();
if(output){
var dataString = j("#wp_con_form").serialize();
j.ajax({
type: "POST",
url: ajaxurl,
dataType:"json",
data: dataString,
}).always(function(data)
{
afterSubmit(data);
});
}
return false;
});
});
在function.php中发送邮件的代码
$name = $_POST['name'];
$phone = $_POST['phone'];
$email = $_POST['email'];
$msg = $_POST['message'];
$to = 'yourname@example.com';
$subject = 'List Qwick';
$message = 'Name: '.$name. "\r\n" .
'Phone: '.$phone. "\r\n" .
'Email: '.$email. "\r\n" .
'Message: '.$msg. "\r\n" .
$headers = "From: ".$email."\r\n" .'X-Mailer: PHP/' . phpversion();
if(wp_mail($to, $subject, $message, $headers))
{
$getMessage = '<p class="success">Your Email Has Been Sent Successfully</p>';
echo json_encode(array('status'=>1,'message'=>$getMessage));
}
else
{
$getMessage = '<p class="error">Mail function not working..</p>';
echo json_encode(array('status'=>0,'message'=>$getMessage));
}
答案 0 :(得分:1)
看起来似乎没有设置ajaxurl,因此您在“未定义”的URL上获得了404。设置该值,您应该设置。
答案 1 :(得分:1)
当您为JavaScript提供Ajax URL时,您实际上正在创建一个名为the_ajax_theme
的对象,其中一个属性称为ajaxurl_anyName
并包含您的Ajax URL。
wp_localize_script( 'themestyle', 'the_ajax_theme', array(
'ajaxurl_anyName' => admin_url( 'admin-ajax.php' )
) );
在您的Ajax通话中,您尝试访问不存在的ajaxurl
。要使用您实际定义的值,您必须使用在wp_localize_script()
中定义的名称。因此,您的Ajax调用应如下所示:
j('#wp_con_frm_btn').click(function(){
var output = validateContact();
if(output){
var dataString = j("#wp_con_form").serialize();
j.ajax({
type: "POST",
url: the_ajax_theme.ajaxurl_anyName,
dataType:"json",
data: dataString,
}).always(function(data)
{
afterSubmit(data);
});
}
return false;
});
我建议使用缩短名称,例如themeSlug.ajaxURL
。
答案 2 :(得分:1)
可能需要WordPress的admin-ajax.php
文件,格式为action
。
<form action="<?php echo admin_url( 'admin-ajax.php' ) ?>" method="post">
此外,您似乎并未在JavaScript中定义ajaxurl
。尝试添加:
var ajaxurl = "<?php echo admin_url('admin-ajax.php'); ?>";
在现有代码中将此行添加到此行的上方或下方:
var dataString = j("#wp_con_form").serialize();