Javascript 使用AJAX和wp_mail()发送邮件
我正在尝试构建一个简单的、支持ajax的联系人表单,但在将其发布到ajax-admin.php hook时没有成功。。。我知道这个问题已经被问了一百万次了(我已经读了每一个问题),所以请耐心听我说: 以下是我的Javascript:Javascript 使用AJAX和wp_mail()发送邮件,javascript,php,ajax,wordpress,Javascript,Php,Ajax,Wordpress,我正在尝试构建一个简单的、支持ajax的联系人表单,但在将其发布到ajax-admin.php hook时没有成功。。。我知道这个问题已经被问了一百万次了(我已经读了每一个问题),所以请耐心听我说: 以下是我的Javascript: submitMail (e) { e.preventDefault(); const data = { action: 'mail_before_submit' };
submitMail (e) {
e.preventDefault();
const data = {
action: 'mail_before_submit'
};
const ajax = new Ajax({
method: 'POST',
url: `${window.location.origin}/wp-admin/admin-ajax.php`,
data: JSON.stringify(data)
});
ajax.on('success', (e) => {
console.log(e)
});
ajax.send();
}
下面是my functions.php中的Wordpress钩子:
add_action('wp_ajax_nopriv_mail_before_submit', 'mail_before_submit');
add_action('wp_ajax_mail_before_submit', 'mail_before_submit');
function mail_before_submit() {
wp_mail('my_email_here@gmail.com', 'title text', 'body text');
echo 'email sent';
die();
}
我真的不确定WP钩子是否会被调用。当我用JS提交表单时,我可以在控制台中看到“XHR已完成加载:POST”“”,但没有其他情况发生-没有发送电子邮件,我得到的响应只是一个0
我对PHP不太熟悉,但经过大量阅读后,我只能断定我做的一切都是对的——在functions.PHP文件中附加钩子和回调,并发送带有action属性的序列化JSON对象,但仍然没有成功
正如你所看到的,这是一个非常简单的例子,但我已经敲了几个小时的头没有任何成功。。。任何帮助都将不胜感激 您需要在查询参数中指定操作。比如/wp admin/admin ajax.php?action=mail\u,然后再提交
submitMail (e) {
e.preventDefault();
const data = {
};
const ajax = new Ajax({
method: 'POST',
url: `${window.location.origin}/wp-admin/admin-ajax.php?action=mail_before_submit`,
data: JSON.stringify(data)
});
ajax.on('success', (e) => {
console.log(e)
});
ajax.send();
}
您需要在查询参数中指定操作。像
/wp admin/admin ajax.php?action=mail\u然后再提交
。谢谢,但不幸的是仍然不起作用-没有收到电子邮件。另外,当我在浏览器中输入新的查询地址时,我仍然会收到0作为响应,而不是我在php calback中所做的“已发送电子邮件”回音…很明显,您的程序没有发送电子邮件。您的主题是否处于活动状态?因为这几乎是我目前唯一的解释了。。对我也有用!