1

このコードを funtions.php に追加しました

function tc_tag_for_cpt($query) {
  if(is_tag() && empty( $query->query_vars['suppress_filters'] ) && !is_admin()) {
    $post_type = get_query_var('post_type');
    $post_type = ($post_type) ?  $post_type : array('resources','post','page');     //,'nav_menu_item'
    $query->set('post_type',$post_type);
    return $query;
  }
}
add_filter( 'posts_orderby', 'sort_query_by_post_type', 10, 2 );
function sort_query_by_post_type( $sortby, $thequery ) {
    if(is_tag() && empty( $query->query_vars['suppress_filters'] ) && !is_admin()) {
        $thequery->set('orderby','post_type');
        if ( !empty($thequery->query_vars['post_type']) && isset($thequery->query_vars['orderby']) && $thequery->query_vars['orderby'] == 'post_type' )
            $sortby = "find_in_set(post_type, '" . implode( ',', $thequery->query_vars['post_type'] ) . "')";
    }
    return $sortby;
}

投稿タイプ別にソートされたタグアーカイブに結果を表示することになっています(リソースはカスタム投稿タイプです)。これは実行されますが、画面の上部にエラー メッセージが表示されます。

「警告: implode() [function.implode]: 279 行目の /home/csleh3/public_html/sandbox/wp-content/themes/aodmarketing/functions.php に無効な引数が渡されました」

これは「内破」行です。

私の目標は、タグ アーカイブの結果を、日付やタイトルではなく、投稿の種類別に並べ替えることです。

4

1 に答える 1

0

$thequery->query_vars['post_type']特定のpost_typeを。のような文字列として返しますpost。あなたはそれを内包することはできません。

あなたはそれを内破しようとすることについての部分を取り除くことができるはずです:

$sortby = "find_in_set(post_type, '" . $thequery->query_vars['post_type'] . "')";
于 2012-09-14T17:59:32.470 に答える