首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >wp_query的条件meta_query和tax_query

wp_query的条件meta_query和tax_query
EN

Stack Overflow用户
提问于 2020-08-13 00:38:30
回答 1查看 764关注 0票数 0

根据某些变量,我需要获取所有帖子或由自定义字段过滤的帖子列表。

我可以获得所有帖子,也可以通过自定义字段和标签通过单独的查询获得过滤后的帖子列表,但我正在尝试组合这些查询。

单个查询返回过滤后的列表:

代码语言:javascript
复制
$paged = ( get_query_var( 'paged' ) ) ? get_query_var( 'paged' ) : 1;
$args = array( 
    'post_type' => 'listings',
    'post_status' => 'publish',
    'orderby' => 'publish_date',
    'order' => 'ASC',                            
    'orderby' => 'date',
    'posts_per_page' => '4',
    'paged' => $paged,
    'meta_query' => array(
        array(
            'key' => 'listing_status',
            'value' => array('active','sold'),
            'compare' => 'IN'
        )
    ),
    'tax_query' => array(
        array(
            'taxonomy' => 'post_tag',
            'field'    => 'slug',
            'terms'    => $agentslug,
        ),
    )                        
);
$query = new WP_Query( $args );

但我也可能需要不经过过滤的名单。我尝试组合这些查询:

代码语言:javascript
复制
$meta_query = array();
$tax_query = array();

if ( $agentslug ) {
    $meta_query[] = array(array(
        'key' => 'listing_status',
        'value' => array('active','sold'),
        'compare' => 'IN'
    ));
    $tax_query[] = array(array(
        'taxonomy' => 'post_tag',
        'field'    => 'slug',
        'terms'    => $agentslug,
    ));
}

$paged = ( get_query_var( 'paged' ) ) ? get_query_var( 'paged' ) : 1;
$args = array( 
    'post_type' => 'listings',
    'post_status' => 'publish',
    'orderby' => 'publish_date',
    'order' => 'ASC',                            
    'orderby' => 'date',
    'posts_per_page' => '4',
    'paged' => $paged,
    'meta_query' => $meta_query,
    'tax_query' => $tax_query                  
);
$query = new WP_Query( $args );

但它们都返回完整的列表。

EN

回答 1

Stack Overflow用户

发布于 2020-08-13 00:41:53

您使用的嵌套数组过多

代码语言:javascript
复制
$meta_query = array();
$meta_query[] = array(array());

的作用与

代码语言:javascript
复制
$meta_query = array();
array_push( $meta_query, array(array()) )

,并具有与

代码语言:javascript
复制
$meta_query = array(array(array()));

变化

代码语言:javascript
复制
if ( $agentslug ) {
    $meta_query[] = array(array(
        'key' => 'listing_status',
        'value' => array('active','sold'),
        'compare' => 'IN'
    ));
    $tax_query[] = array(array(
        'taxonomy' => 'post_tag',
        'field'    => 'slug',
        'terms'    => $agentslug,
    ));
}

代码语言:javascript
复制
if ( $agentslug ) {
    $meta_query[] = array(
        'key' => 'listing_status',
        'value' => array('active','sold'),
        'compare' => 'IN'
    );
    $tax_query[] = array(
        'taxonomy' => 'post_tag',
        'field'    => 'slug',
        'terms'    => $agentslug,
    );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63381066

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档