在显示帖子之前排序术语

时间:2018-10-19 作者:Cha

My question is close to other questions, but I dont\' have enough reputation to comment.

I\'m working for a restaurant and I \'d like, for my menu page, to organise my posts "meal" under terms "cat_meal".

This terms should respect an order (dessert after starter for example). And that\'s my probleme : I tried so many snippets, that I don\'t know which one I should write here... Here are some picture to explain, I hope. Page menu Page menu with comments But, there is always something wrong : either I can display my term in a right order and my query post is not good. Or meal posts are under the good terms, but, the order of the terms are wrong. Or, worth, nothing happens.

Here are two tests, thanks for your time and help :

$args_tax = [
    \'parent\'    => 0,
    \'hide_empty\' => 0,
    \'meta_key\'      => \'ordre\',// I added an ACF with number from 1 to 8 to order
    \'orderby\'   => \'meta_value\',
    \'order\'     => \'ASC\'
];

$terms = get_terms(\'cat_meal\', $args_tax); // tax cat_meal
// print_r($terms);

if (!empty($terms)):
    foreach ($terms as $term):
        $argsPost = [
            \'post_type\' => \'meal\',//CPT meal
             \'posts_per_page\' => -1
        ];

        $query = new WP_Query($argsPost);
        while ($query->have_posts()) : $query->the_post();
            echo $term->name ;
            the_title();
        endwhile;
        wp_reset_postdata(); // reset the query 
    endforeach;
endif;
//PROBLEM : under each term, every posts are displaying ! I don\'t understand why...

Second version from this question Get all categories and posts in those categories


$args = array( 
        \'post_type\' => \'meal\',  
        \'posts_per_page\' => -1
    );

    $query = new WP_Query($args);   
    $q = array();

    while ( $query->have_posts() ) { 
        $query->the_post(); 
        $a = \'\' . get_the_title() .\'\';
        $terms = wp_get_post_terms( $post->ID, \'cat_meal\', $args );
        foreach ( $terms as $term) {
            $term_link = get_term_link( $term );
            $b = \'\'.$term->name.\'\';    
        }
        $q[$b][] = $a; 
    }
    wp_reset_postdata();
    foreach ($q as $key=>$values) {
        echo $key;
            foreach ($values as $value){
                echo $value;
            }
    }

The posts are well displaying under the terms, BUT the terms have wrong order (dessert before pizza)

I\'ve just found this answer too, but I\' dont undetsand wher the taxonomy is declared : Ordering Posts with Custom Taxonomy Terms Array.

I would really appreciate some advices into my fog : thanks

2 个回复
SO网友:Antti Koskinen

你可以使用tax_query 仅获取当前正在循环使用的术语的帖子。

$argsPost = [
 \'post_type\' => \'meal\',//CPT meal
 \'posts_per_page\' => -1,
 \'meta_key\' => \'ordre\', 
 \'orderby\'   => \'meta_value\', // Use the custom post order
 \'order\'     => \'ASC\' 
 \'tax_query\' => array(
    array(
        \'taxonomy\' => \'cat_meal\',
        \'field\'    => \'term_id\',
        \'terms\'    => $term->term_id, // Only query the posts that have the current term in foreach loop
    ),
 ),
];
尝试更换$argsPost 在您的第一个代码示例中,看看会发生什么。

我模糊地记得自己在几个网站上做过这样的事情。

EDIT 2018年10月20日

我看了看Ordering Posts with Custom Taxonomy Terms Array 您链接的讨论,您也可以使用米洛发布的解决方案。

类似这样的内容(可能需要一些调整)

$args = array(
\'post_type\' => \'meal\',
\'posts_per_page\' => \'-1\',
// add extra sorting related key/value pairs here
);
$my_query = new WP_Query( $args );

// you original get_terms function
$args_tax = [
\'parent\'    => 0,
\'hide_empty\' => 0,
\'meta_key\'      => \'ordre\',// I added an ACF with number from 1 to 8 to order
\'orderby\'   => \'meta_value\',
\'order\'     => \'ASC\'
];
$terms = get_terms(\'cat_meal\', $args_tax); // tax cat_meal

// Loop terms
if ( ! is_wp_error( $terms ) && ! empty( $terms )  ) {
    foreach( $terms as $term ) {
        while( $my_query->have_posts() ) {
            $my_query->the_post();
            if( has_term( $term->term_id, \'cat_meal\' ) ){
                // output post
            }
        }
        $my_query->rewind_posts(); // rewind custom query for the next foreach term loop
    }
}
这样,您只需进行一次WP\\u查询,只需对每个术语反复循环结果。这可能比为每个术语单独执行WP\\u查询更好,但这只是一种预感。

SO网友:Cha

再次感谢Antti Koskinen!这是我的最终代码:


$myTax=\'cat_meal\';

// I use an ACF named "ordre" from 1 to 7  to control the order of my terms
$_terms = get_terms($myTax, array(
     \'parent\'   => 0, // no child term
     \'meta_key\' => \'ordre\',// my ACF
     \'orderby\'  => \'meta_value\',
     \'order\'    => \'ASC\'// from 1 to ...
) );

foreach ($_terms as $term) :
    $term_slug = $term->slug;

    $_posts = new WP_Query( array(
        \'post_type\'         => \'meal\',// my CPT
        \'posts_per_page\'    => -1,
        \'tax_query\' => array(
            array(
                \'taxonomy\' => $myTax,
                \'field\'    => \'slug\',
                \'terms\'    => $term_slug,
            ),
        ),
    ));

    if( $_posts->have_posts() ) :

        echo $term->name; // The term

        while ( $_posts->have_posts() ) : $_posts->the_post(); 

           the_title(); // the different meals under this term

         endwhile;

    endif;
哎哟,故事结束了,再次感谢。

结束

相关推荐

WP_Query order by two values

我试图让WP\\u查询按两个不同的值排序,但我不知道怎么做。我试图通过结束时间在一个查询中获取事件。在每个datetime值为YYYY-MM-DD H:i:s的事件中都有自定义的ending\\u date\\u time字段。我需要查询以获取值,以便第一个是最接近结束的事件,依此类推,如果有已结束的事件,则它们位于尚未结束的事件之后。使用MySQL,我会这样做:SELECT * FROM events ORDER BY event_endtime < NOW(), event_endtime AS