Перечислите все сообщения в пользовательском типе поста по таксономии


25

Есть ли способ, которым я могу перечислить все посты в определенном настраиваемом типе поста и упорядочить их в соответствии с пользовательским термином таксономии, прикрепленным к ним?

Например;

Термин № 1 таксономии
Тип
сообщения Тип
сообщения Тип сообщения

Термин таксономии № 2
Тип
сообщения Тип сообщения

Любая помощь будет наиболее ценной.

Спасибо.

Ответы:


52

Попробуй это

$custom_terms = get_terms('custom_taxonomy');

foreach($custom_terms as $custom_term) {
    wp_reset_query();
    $args = array('post_type' => 'custom_post_type',
        'tax_query' => array(
            array(
                'taxonomy' => 'custom_taxonomy',
                'field' => 'slug',
                'terms' => $custom_term->slug,
            ),
        ),
     );

     $loop = new WP_Query($args);
     if($loop->have_posts()) {
        echo '<h2>'.$custom_term->name.'</h2>';

        while($loop->have_posts()) : $loop->the_post();
            echo '<a href="'.get_permalink().'">'.get_the_title().'</a><br>';
        endwhile;
     }
}

Мы получаем все условия таксономии, перебираем их и запускаем ссылку на заголовок для каждого поста, который принадлежит этому термину. Если вам нужно изменить порядок терминов таксономии, вы можете сделать это с помощью плагина довольно легко. Я полагаю, изменить порядок таксономии . Но обратите внимание, что этот плагин добавляет (!) Еще один столбец к вашей таблице при активации и не удаляет его при деактивации !


Привет @ GhostToast Это прекрасно работает, у меня есть прямой вопрос, как я могу отфильтровать это по таксономии, у меня есть теннис, гольф, футбол, волейбол, эти коды приносят им все с их постом, который проверен таксономии, Как я могу фильтровать показывать только таксономию футбола со своими постами.
Родриго

@RodrigoZuluaga, это будет простой запрос. забрать $custom_termsи foreach()и просто определить 'terms'вручную слизняк или что угодно.
GhostToast

Я думаю, это немного отличается, но ваш код чертовски хорош $ args = array ('post_type' => 'publica', 'tax_query' => array (array ('taxonomy' => 'comision-publicaciones', 'field' = > 'имя', 'условия' => массив ($ ter_name)),),);
Родриго

1

Не особенно элегантное решение, но вы можете создать несколько запросов для каждого конкретного термина, а затем вывести их. Надеюсь, кто-то может придумать более удобный способ автоматического извлечения терминов для изменения вывода / сортировки. Но это поможет тебе.

<?php

//First Query for Posts matching term1
$args = array(
    'tax_query' => array(
        array(
            'taxonomy' => 'taxonomy_1',
            'field' => 'slug',
            'terms' => array( 'term1' )
        ),
    ),
    'post_type' => 'my-post-type'
);
$query = new WP_Query( $args );

if ( have_posts() ) {

    $term = $query->queried_object;

    echo 'All posts found in ' . $term->name;

    while ( have_posts() ) : the_post();
        //Output what you want
        the_title();
        the_content();
    endwhile;
}

//RESET YOUR QUERY VARS
wp_reset_query();

//Second Query for term2
$args = array(
    'tax_query' => array(
        array(
            'taxonomy' => 'taxonomy_1',
            'field' => 'slug',
            'terms' => array( 'term2' )
        ),
    ),
    'post_type' => 'my-post-type'
);
$query = new WP_Query( $args );

if ( have_posts() ) {

    $term = $query->queried_object;

    echo 'All posts found in ' . $term->name;

    while ( have_posts() ) : the_post();
        //Output what you want
        the_title();
        the_content();
    endwhile;
}

0

Хороший! Решение GhostOne было то, что я искал. В моей ситуации пользовательский тип записи был «minining_accidents», а связанные с ним пользовательские таксономии - «типы аварий», в которых было несколько терминов. Моя идея состояла в том, чтобы создать собственный виджет для отображения списка постов по условиям в этой пользовательской таксономии. В моем пробном прогоне он получил то, что хотел. Отдых был ель. Вот мой код:

function fn_get_list_of_mining_accident_types()
{
    $custom_taxonomy='accident-types';  
    $custom_terms = get_terms($custom_taxonomy);    
    $str_return='<ul>';
    foreach($custom_terms as $custom_term) 
    {
        wp_reset_query();
        $args = array(
            'post_type' => 'minining_accidents',
            'tax_query' => array(               
                array(
                    'taxonomy' => $custom_taxonomy,
                    'field' => 'slug',
                    'terms' => $custom_term->slug,
                ),
            ),
        );  

        $loop = new WP_Query($args);

        $term_name=$custom_term->name;
        $term_slug=$custom_term->slug;
        $term_link=get_term_link($term_slug, $custom_taxonomy);

        $str_return.='<li><a href="'.$term_link.'">'.$term_name.'</a>';

        if($loop->have_posts()) 
        {
            $str_return.='<ol>';

            while($loop->have_posts()) : $loop->the_post();
                $str_return.='<li><a href="'.get_permalink().'">'.get_the_title().'</a></li> ';
            endwhile;

            $str_return.='</ol>';           
         }
         $str_return.='</li>';
    }
    $str_return.='</ul>';
    return $str_return;
}

Да! Всегда есть возможность для дальнейшего улучшения кода.


-1

Чтобы показать список пользовательских сообщений из пользовательской таксономии

$args = array(
    'tax_query' => array(
        array(
            'taxonomy' => 'your-custom-taxonomy',
            'field' => 'slug',
            'terms' => array( 'your-term' )
        ),
    ),
    'post_type' => 'your-post-type'
);
$loop = new WP_Query($args);
     if($loop->have_posts()) {
    $term = $wp_query->queried_object;
     while($loop->have_posts()) : $loop->the_post();
        //Output what you want      
   echo '<li><a href="'.get_permalink().'">'.get_the_title().'</a></li>';
      endwhile;
}

заглавие

  • Элемент списка
  • Элемент списка
  • Элемент списка
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.