到目前为止,在本系列中,您已经学习了如何使用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