Nakkan Base

カテゴリー名の取得と表示

「カテゴリー検索をしたときにズラズラッと出てくる記事のトップに、そのカテゴリー名を表示したい」という時。

get_the_category()』を使いましょう。

『get_the_category()』では、「カテゴリーID」「カテゴリー名」「カテゴリースラッグ」などが取得できます。

<?php   
      $category = get_the_category();   
      $cat_id   = $category[0]->cat_ID;   
      $cat_name = $category[0]->cat_name;   
      $cat_slug = $category[0]->category_nicename;   

                    echo $cat_id;   // カテゴリーIDを表示   
                    echo $cat_name;   // カテゴリー名を表示
                    echo $cat_slug;  // カテゴリースラッグを表示   
?>

私の場合、「カテゴリー名」だけ表示できれば良いので、

<?php $category = get_the_category();  echo $category[0]->cat_name; ?>

って感じでしょうか。

でも、実際に出力してみると、なんだか使い勝手が悪い。出てほしいカテゴリー名が出てこないのだ。

なので、属している全てのカテゴリ名を取得することにしました。

<?php 
          $categories = get_the_category();  
                if($categories) { 
                          foreach($categories as $categorie) { 
                                  $output .= $categorie->name; 
                          } 
                          echo $output; 
                 } 
?>

これで出てほしいカテゴリー名も全て出てくれましたが、スペースも「、」もなく文字が連なって出てくるので、これでは見栄えが悪すぎるだろ…。

それで、今一度カテゴリーを整理して、親子関係を見直してみることにしました。その上で、親カテゴリー名のみを表示したいと思いました。

解決してくれてる人がいらっしゃいました♪

<?php
$cats = get_the_category();
$cat = $cats[0];
$cat_name = $cat->cat_name;
$cat_slug = $cat->category_nicename;
if ($cat->parent){
$parent = get_category($cat->parent);
$cat_name = $parent->cat_name;
$cat_slug = $parent->category_nicename;
echo "<span class=\"ico-cate $cat_slug\">$cat_name</span>";
} else {
echo "<span class=\"ico-cate $cat_slug\">$cat_name</span>";
}
?>

これで親カテゴリー名のみがきちんと表示されるようになり、すっきりいたしました。

【参考になったサイト様】

★投稿記事のカテゴリ名の表示、カテゴリIDの取得

★【WordPress】カテゴリを取得できるget_the_categoryの使い方

★【WordPress】親カテゴリの情報のみ取得したい