使用Javascript变量作为WP_Query参数

时间:2015-12-07 11:48:22

标签: javascript php jquery ajax wordpress

我在尝试将Javascript变量用作WordPress查询参数时遇到了一些问题。

我正在使用AJAX Post Request向Wordpress发送一个post_ids的Javascript数组。

$.post('url', { data: requestIds }, function(response) { console.log(response) });

我基本上试图将'requestIds'的Javascript数组作为post__in WP_Query参数传递。

$COMPARISON_QUERY = new WP_Query(array(
    'post_type' => array('Post'),
    'post__in' => // this is where the array would be passed as a parameter
));

这是处理请求的PHP:

$response_object = DecodeJSONString($_POST['data']);

function DecodeJSONString($string) {
    $decoded_string = json_decode($string);
    return $decoded_string; // this would be the query parameter
}

感谢您的反馈!

1 个答案:

答案 0 :(得分:1)

您应该使用WordPress ajax functions进行ajax请求,而不是发布到直接执行工作的php文件。

假设您使用的自定义php文件名为process_post.php。而不是直接发布到您的自定义php文件,发布到admin-ajax.php并处理functions.php文件中的帖子。

在前端页面上:

<script>
    var ajaxUrl = "<?php echo admin_url('admin-ajax.php'); ?>"; // This will get the approriate ajax url using wordpress functionality
    $.post(  ajaxUrl, 
         { 
            'action': 'my_action',
            'requestIds': requestIds // Assuming you have your requestIds var populated already 
         },
         function(response) {
           console.log(response)
         });
</script>

现在在php方面,有一个关于注册你的ajax动作my_action的一些棘手/不直观的部分。这是一个命名约定,您可以在my_actionwp_ajax之后附加操作名称wp_ajax_no_priv。请注意,如果普通用户不应该触摸它,则不会将您的操作挂钩到wp_ajax_no_priv

第一个参数是命名约定,第二个参数是您的自定义函数名称:

<?php // in functions.php
add_action( 'wp_ajax_my_action', 'my_action_callback' );
add_action( 'wp_ajax_nopriv_my_action', 'my_action_callback' );
?>

现在你已经设置了ajax动作!现在在functions.php中创建回调函数。我经常只从这一点包含单独的php文件,如下所示:

<?php // Still in functions.php
function my_action_callback(){
    include_once('my_code.php');
}
?>

现在您已经正确设置了所有这些,您不再需要包含不同的核心WordPress类!这是通过这种方式设置它的所有麻烦的主要原因。

在我的示例中位于您主题中的my_code.php中:

<?php
$COMPARISON_QUERY = new WP_Query(array(
    'post_type' => array('Post'),
    'post__in' => json_decode( $_POST['requestIds'] ),
));