Maj*_*0od 7 php ajax wordpress jquery
我正在尝试使用Ajax通过我创建的网络表单发送电子邮件,但我迷路了.我不知道Ajax如何在Wordpress中运行.
我首先创建了一个动作
add_action( 'wp_ajax_siteWideMessage', 'wpse_sendmail' );
Run Code Online (Sandbox Code Playgroud)
应该检索数据并发送邮件的功能是:
function wpse_sendmail()
{
$for = like_escape($_POST['forwhat']);
$email = like_escape($_POST['email']);
$headers = 'From: '.$email ."\r\n".'Reply-To: '.$email;
$message = like_escape($_POST['message_message']);
$respond = like_escape($_POST['message_email']);
wp_mail( "support@ontrgt.net", "(OTN) Support: ".$support, $message, $headers);
}
Run Code Online (Sandbox Code Playgroud)
最后,js是这样的:
$("#contact-send").click(function(){
var forwhat = $("#contact-for").val();
var name = $("#contact-name").val();
var email = $("#contact-email").val();
$.post( "<?php echo esc_js( site_url() ) ?>", { siteWideMessage:"null", forwhat: forwhat, name: name, email:email }, function(){
console.log("success");
});
});
Run Code Online (Sandbox Code Playgroud)
我不太清楚我在这里缺少什么.有人可以帮我理解Wordpress的Ajax流程吗?
UPDATE
到目前为止,我更新了我的代码:
PHP
add_action( 'wp_ajax_siteWideMessage', 'wpse_sendmail' );
add_action( 'wp_ajax_nopriv_siteWideMessage', 'wpse_sendmail' );
function wpse_sendmail()
{
$for = $_POST['forwhat'];
$email = $_POST['email'];
$headers = 'From: '.$email ."\r\n".'Reply-To: '.$email;
$message = $_POST['message_message'];
$respond = $_POST['message_email'];
/*if(wp_mail( "support@ontrgt.net", "(OTN) Support: ".$for, $message, $headers))
{
echo "WOOHOO";
}*/
if($for)
{
//Just to see if there is any response.
echo "Whoohoo";
}
die();
}
Run Code Online (Sandbox Code Playgroud)
JS
$("#contact-send").click(function(){
var forwhat = $("#contact-for").val();
var name = $("#contact-name").val();
var email = $("#contact-email").val();
var data = { action:'siteWideMessage', forwhat:forwhat, name:name, email:email };
$.post('<?php echo admin_url("admin-ajax.php"); ?>', data, function(response) {
alert(response);
});
});
Run Code Online (Sandbox Code Playgroud)
Wordpress仍然没有响应我的AJAX命令.我正在使用inspect元素,我看不到任何数据被传递.
The*_*pha 12
首先,您需要添加两个操作,一个用于明确要求使其工作的非登录用户,例如类似这样的操作(基本上在您的functions.php
文件中):
add_action( 'wp_ajax_siteWideMessage', 'wpse_sendmail' );
add_action( 'wp_ajax_nopriv_siteWideMessage', 'wpse_sendmail' );
Run Code Online (Sandbox Code Playgroud)
然后,你需要admin-ajax.php
在jQuery
函数中发出请求,你可以使用这样的东西:
$("#contact-send").click(function(e){
e.preventDefault(); // if the clicked element is a link
//...
var data = { 'action':'siteWideMessage', 'more':'values' };
$.post('<?php echo admin_url('admin-ajax.php'); ?>', data, function(response) {
console.log(response);
});
});
Run Code Online (Sandbox Code Playgroud)
确保放在服务器端exit/die
的末尾handler
,例如:
function wpse_sendmail()
{
// Process the post data...
if(mail(...)) {
echo 'success';
}
else {
echo 'failed';
}
die();
}
Run Code Online (Sandbox Code Playgroud)
在您的success
回调中,response
变量将获得从服务器端发送的响应,即success/failed
.有更好的方法(使用wp_localize_script等).阅读这篇详细的文章.此外,如果您想要返回json
响应,那么您可以使用$.json('url', data, func)
.
如果你感到困惑,那么让我告诉你,你应该发出请求admin-ajax.php
并传递action
请求,在这种情况下它是siteWideMessage
,所以WordPress
将调用handler
使用add_action
钩子注册的那个,在你的情况下它是wpse_sendmail
.Eid Mubarak :-)
归档时间: |
|
查看次数: |
12497 次 |
最近记录: |