到目前为止,在本系列中,您已经学习了如何使用 WP_Query
创建在主题或插件中使用的自定义查询。
在大多数情况下,您将使用 WP_Query
以及一组全新的参数,这些参数与主查询中的参数分开,但是如果您想在参数中包含主查询怎么办?
您可能想要执行此操作的示例包括:
- 在类别或分类页面上,仅显示一种帖子类型的帖子
- 在类别页面上,显示包含当前类别和其他类别或标签或分类术语的帖子
- 在帖子类型的页面上,仅显示具有特定元数据的帖子
我可以继续说下去,有很多机会可以将主查询与您自己的自定义查询相结合。
我将通过三个示例来演示这一点:第一个示例是一个带有一个循环的简单示例;第二个将使用 foreach
输出多个循环,每个循环对应一种帖子类型;第三个将使用两个单独的查询在类别存档上输出两种帖子类型。
根据主查询定义变量
但是,您要将主查询与 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
参数以类别 slug 作为参数,因此需要在变量后面添加 ->slug
来输出类别 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
不仅可以创建与主查询分离的完全自定义查询,还可以合并当前查询的对象并创建更强大的查询在存档页面上。
上面的示例也可以使用其他存档类型来完成:用于分类、作者、日期等。看看你是否能想出更多的可能性!
以上就是合并WP_Query与主查询的详细内容,更多请关注php中文网其它相关文章!