2 自定义 wp_query 使用与 'orderby' => 'rand' 相同的兰特?

问题描述 投票:0回答:2

在我的主页上,我显示了 9 个帖子,我有一个加载更多按钮(使用 ajax)调用其他 9 个帖子等等。目前我按“日期”订购,但我想随机订购。问题是我的第一个 wp_query orderby rand 显示 9 个随机帖子,当我加载更多帖子时,我的第二个 wp_query orderby random 也可以显示前 9 个帖子中的相同帖子。

如何使用相同的 random 随机化 2 wp_query?或者还有其他方法吗?


正如社区成员已经建议的那样,我尝试将可见 Id 存储在数组中并使用

post__not_in
像:

$query = new WP_QUERY(array(
        'post_type' => 'my_posts',
        'posts_per_page' => 9,
        'orderby' => 'rand',
        'post__not_in' => $postNoIn,
        'paged' => $paged

    ));

但这并没有解决我的问题。

$paged
变量是我帖子的当前页码。我有 32 个帖子,我将它们按 9 乘 9 排列,所以有 4 页。当我使用上面的第二个 wp_query 显示时,我得到 9 个随机帖子减去可能的 9 个第一个帖子,所以我可以有少于 9 个帖子并且当到达最后一页时查询停止。我将有大约 28 个帖子而不是 32 个,因为查询在第 4 页停止,直到显示所有帖子。

提前感谢您的回答!

我终于成功了! 这是我的答案

我更改我的第一个查询以通过“rand”获取所有后订单,例如:

$args = array(
        'post_type' => 'my_posts',
        'posts_per_page' => -1,
        'orderby' => 'rand'
    );

然后在我的循环中我显示前 9 个帖子,在 9 个帖子之后我得到所有其他帖子的 ID

<?php
$index = 0;
$idsInt = array();

while ($the_query->have_posts()):
$the_query->the_post();

    if ($index < 9) : 

        get_template_part('part-template/content', get_post_format());
        $index++;

    else :

        array_push($idsInt, get_the_ID());

    endif; 

endwhile;

之后我准备我的数据以与ajax一起使用,为此我将我的

int
元素列表转换为
string
列表

$index = 0;
$idsString = array();

foreach ($idsInt as $id) {
    if ($index == 0) {
        $idsString .= " \"" . $id . "\"";
    } else {
        $idsString .= ", \"" . $id . "\"";
    }
    $index++;
}

这是我的“加载更多”按钮,我输入“data-id”我的ID列表

<div class="text-center">
    <a id="btn-load-more" data-id='[<?php echo $idsString ?>]' 
        class="home-load-more"
        data-page="1"
        data-url="<?php home_url(); ?>/wp-admin/admin-ajax.php" >
        <span class="text"><?php _e('Load More') ?></span>
    </a>
</div>

在我的 script.js 中,我的 ajax 函数看起来像:

$(document).on('click', '.home-load-more', function () {

    let that = $(this);
    let page = that.data('page');
    let newPage = page + 1;
    let ajaxurl = that.data('url');
    let ids = that.data('id');

    $.ajax({

        url: ajaxurl,
        type: 'post',
        data: {

            page: page,
            action: 'home_load_more',
            foo : ids

        },
        error: function (response) {

            console.log(response);

        },
        success: function (response) {

            if (!(response === "")) {

                that.data('page', newPage);
                $('.my_row').append(response);

            }
        }
    });
});

我的

$_POST['page']
包含许多页面,这些页面在每次加载更多调用时都会增加,我将解释为什么我稍后会使用它,我的
$_POST['foo']
包含我在第一个查询循环中创建的 ID 列表。

现在我的 php 功能正常了! (在 php 注释中解释我的代码!)

function home_load_more()
{

    $ids = ($_POST['foo']);
    $paged = $_POST["page"];
    $postIn = array();

    // I want to display only 9 posts on each calls
    for ($i = 0; $i < 9; $i++) {

        /* Here is my strange calcul to get ids 
         - from 0 to 8 on the first call
         - from 9 to 17 on the second call
         - from 18 to 26 on the third call
         and so on... 
         That is why I use the $paged, to get
         a value that is increment by one on every calls. */

        // Break if they are no more ids in the list
        if ($ids[($paged - 1) * 9 + $i] == null) {
            break;
        }

        // $postIn contains 9 posts IDs
        array_push($postIn, $ids[($paged - 1) * 9 + $i]);
    }

    $query = new WP_QUERY(array(
        'post_type' => 'my_posts',
        'orderby' => 'post__in',   // here I give my list of 9 ids
        'post__in' => $postIn
    ));

    if ($postIn[0] == null) {
        // Load More button won't display any posts
        wp_reset_postdata();
    } else {
        if ($query->have_posts()) {

            while ($query->have_posts()) {
                $query->the_post();
                get_template_part('part-template/content', get_post_format());
            }
        }
        wp_reset_postdata();
    }

    die();
}

就是这样!我认为有一个最好的方法可以做到这一点,但我仍然想向您展示我的代码。希望这可以帮助别人,如果您有任何意见、问题或想法,请随时在评论部分告诉我!

php jquery ajax wordpress custom-post-type
2个回答
1
投票

只需将已经可见的 id 存储在数组中的某处,当请求加载更多时,发送该数组,然后将其包含到

$args

$args = array (
...
'post__not_in' => array( 1, 2, 3),
...
);

0
投票

如果你在一个会话中存储种子,你可以在第 2 页或第 3 页中有相同的顺序,应该比你的解决方案更容易。 https://wordpress.stackexchange.com/questions/31647/is-it-possible-to-paginate-posts-correctly-that-are-random-ordered

$args['posts_per_page'] = 10;
if (!isset($_SESSION['seed'])) {
    $_SESSION['seed'] = mt_rand();
}
$args['orderby'] = 'RAND(' . $_SESSION['seed'] . ')';
$query = new WP_Query($args);

你是对的,Archit Gargi,我添加了代码

© www.soinside.com 2019 - 2024. All rights reserved.