结合WP_Query与主查询

到目前为止,在本系列中,您已经学习了如何使用WP_Query创建用于主题或插件的自定义查询。

在大多数情况下,您将使用WP_Query和一组全新的参数,这些参数与主查询中的参数分开,但是如果要将主查询包括在参数中怎么办?

何时需要执行此操作的示例包括:

  • 在类别或分类页面上,仅显示一种帖子类型的帖子
  • 在类别页面上,显示具有当前类别和其他类别或标签或分类术语的帖子
  • 在帖子类型的页面上,仅显示带有某些元数据的帖子

我可以继续—将主查询与您自己的自定义查询组合在一起的机会很多。

我将通过三个示例进行演示:第一个是一个循环的简单示例。 第二个将使用foreach输出多个循环,每个帖子类型一个。 第三个将通过使用两个单独的查询在类别存档上输出两种帖子类型。

根据主查询定义变量

但是,要将主查询与WP_Query结合使用,需要以一种易于在WP_Query参数中使用的方式存储当前查询对象。 最简单的方法是将其分配给变量。

您可以在定义WP_Query参数之前执行此WP_Query ,如下所示:

$mainquery = get_queried_object();

get_queried_object()函数返回当前查询的对象,无论可能是什么。 在单个帖子中,它将仅返回帖子对象,而在存档中,它将返回类别,标签,术语对象或与存档相关的任何对象。 它返回查询对象的ID。

然后,可以在WP_Query参数中使用此$mainquery变量。 现在让我们看一些例子。

示例1:在类别页面上仅显示一种帖子类型的帖子

假设您的网站已添加自定义帖子类型,并且您已为该自定义帖子类型启用了类别。 在每个类别的类别归档中,您不想显示帖子:相反,您想要显示新帖子类型的帖子,我们称其为product

您的查询可能看起来像这样:

<?php

$mainquery = get_queried_object();

$args = array (
    'category_name' => $mainquery->slug,
    'post_type' => 'product'
);

// Custom query.
$query = new WP_Query( $args );

// Check that we have query results.
if ( $query->have_posts() ) {

    // Start looping over the query results.
    while ( $query->have_posts() ) {

        $query->the_post();

        // Contents of the queried post results go here.

    }

}

// Restore original post data.
wp_reset_postdata();

?>

因为我上面使用的category_name参数将category slug作为其参数,所以您需要在变量后添加->slug以输出category slug。

这将为您提供一个查询,该查询将从具有当前查询类别的数据库中获取product帖子类型的帖子。 您可以在category.php页面模板上使用它。

注意:您还可以使用pre_get_posts钩子来修改主查询,并结合条件函数来检查类别存档,以实现此结果。

示例2:将主查询与WP_Query和foreach组合以输出多个循环

下一个示例将输出当前类别页面的所有帖子,但不是将它们全部显示在一个块中,而是按帖子类型将它们分开。

这意味着您可以使用CSS将帖子类型分类为页面上的块或列,也可以将它们分成不同的列表。

为此,您将使用以下代码:

<?php

$mainquery = get_queried_object();

$post_types = get_post_types();

foreach ( $post_types as $post_type ) {

    $args = array(
        'category_name' => $mainquery->slug,
        'post_type' => $post_type
    );

    // Custom query.
    $query = new WP_Query( $args );

    // Check that we have query results.
    if ( $query->have_posts() ) {

        // Start looping over the query results.
        while ( $query->have_posts() ) {

            $query->the_post();

            // Contents of the queried post results go here.

        }

    }

    // Restore original post data.
    wp_reset_postdata();

}

?>

这使用了我们之前使用的$mainquery变量,但是它还添加了$post_types变量来存储在网站上注册的所有帖子类型,以及一个$post_type变量来依次存储每个单独的帖子类型。

示例3:两种帖子类型的两个单独的查询

最后一个示例与第二个示例相似,但是将帖子类型分为两个单独的查询,每个查询都有自己的独特循环。 这使您可以更好地控制每种商品的显示内容,因此可以显示与商品不同的帖子,可能包括商品的特色图片或为商品提供不同的布局。

假设您的网站已注册了product发布类型,并为其启用了类别,并且您还在撰写具有相同类别的博客文章。 在每个类别存档页面上,您要显示最近的十个帖子,然后要显示同一类别中所有产品的列表。

为此,您将使用以下代码:

<?php

$mainquery = get_queried_object();

// First query arguments for posts.
$args = array (
    'category_name' => $mainquery->slug,
    'post_type' => 'post',
    'posts_per_page' => '10'
);

// Custom query.
$query = new WP_Query( $args );

// Check that we have query results.
if ( $query->have_posts() ) {

    // Start looping over the query results.
    while ( $query->have_posts() ) {

        $query->the_post();

        // Contents of the queried post results go here.

    }

}

// Restore original post data.
wp_reset_postdata();

// Second query arguments for products.
$args = array (
    'category_name' => $mainquery->slug,
    'post_type' => 'product',
    'posts_per_page' => '-1'
);

// Custom query.
$query = new WP_Query( $args );

// Check that we have query results.
if ( $query->have_posts() ) {

    // Start looping over the query results.
    while ( $query->have_posts() ) {

        $query->the_post();

        // Contents of the queried post results go here.

    }

}

// Restore original post data.
wp_reset_postdata();

?>

然后,您将不同地编写每个循环以为每种帖子类型输出不同的数据。

摘要

从上面的示例中可以看到,不仅可以使用WP_Query创建与主查询分开的完全自定义查询,而且可以合并当前查询的对象并在存档页面上创建更强大的查询。

上面的示例也可以使用其他存档类型来完成: 分类法 ,作者,日期等。 看看是否可以提出更多可能性!

翻译自: https://code.tutsplus.com/tutorials/combining-wp_query-with-the-main-query--cms-23209

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值