WordPress: разные параметры для каждого типа записи в WP_Query

#php #wordpress #args

#php #wordpress #аргументы

Вопрос:

У меня есть два типа сообщений (type-A и type-B) и две таксономии (tax-1 и tax-2), оба назначены каждому типу сообщения. Это означает, что сообщения из type-A могут содержать термины из tax-1 и tax-2, а сообщения из type-B также могут содержать термины из tax-1 и tax-2 .

Я хочу, чтобы мой WP_Query выводил все сообщения из type-A, которые содержат определенные условия tax-1. Но я не хочу выводить сообщения типа B, содержащие эти термины tax-1, что, к сожалению, делает мой WP_Query. То же самое должно применяться к tax-2, при этом должны выводиться только сообщения из type-B, содержащие термины из tax-2.

Я уже пытался создать для этого два аргумента $, но мне не удалось объединить два аргумента $.

 function my_function($args) {
    global $post;

    $args = array(
            'post_type' => array('type-A','type-B'),
            'tax_query' => array(
                'relation'  => 'OR',
                 array(
                    'taxonomy' => 'tax-1',
                    'field'    => 'term_id',
                    'terms'    => array(11, 12, 13),
                ),
                array(
                    'taxonomy' => 'tax-2',
                    'field'    => 'term_id',
                    'terms'    => array(21, 22, 23),
                ),
            ),
        );

    return $args;
} 
  

Ответ №1:

Теперь я сам нашел решение, которым я хотел бы поделиться здесь.

Идея состоит в том, чтобы создать запрос для каждого из двух типов записей. Для каждого типа сообщения я получу результат в виде списка с использованием идентификаторов сообщений wp_list_pluck() . С array_merge() помощью я объединяю списки в один, который может быть включен в окончательный запрос post__in .

 function my_function($query_args) {
    global $post;
    
    
    $query_args_1 = new WP_Query(array(
            'post_type' => array('type_A'),
            'tax_query' => array(
               'relation'   => 'OR',
                array(
                    'taxonomy' => 'tax_1',
                    'field'    => 'term_id',
                    'terms'    => array(11, 12, 13),
                ),
            ),
));
        $list_id_1 = wp_list_pluck( $query_args_1->posts, 'ID' );
        
        $query_args_2 = new WP_Query(array(
            'post_type' => array('type_B'),
            'tax_query' => array(
                'relation'  => 'OR',
                 array(
                    'taxonomy' => 'tax_2',
                    'field'    => 'term_id',
                    'terms'    => array(21, 22, 23),
                ),
            ),
));
        $list_id_2 = wp_list_pluck( $query_args_2->posts, 'ID' );
        
        $merged_list = array_merge($list_id_1, $list_id_2);
        
        $query_args = array(
            'post_type' => array('type_A', 'type_B'),
            'orderby'   => 'relevance',
            'order'     => 'ASC',
            'post__in'  => $merged_list
);

    return $query_args;

}