get_the_category()で親子カテゴリーを親子順に表示する方法
MENU
  1. HOME
  2. WordPress / カスタマイズ
  3. get_the_category()で親子カテゴリーを親子順に表示する方法

最近の作業実績

  • 2024年04月06日非レスポンシブのサイトをレスポンシブ化いたしました。
  • 2024年04月05日テーマファイルが編集できない不具合を解消いたしました。
  • 2024年04月04日WordPress、テーマ、プラグイン、のバージョンアップを担当いたしました。
  • 2024年04月03日不具合で表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年04月02日お問い合わせフォームを再構築いたしました。
  • 2024年04月01日不具合で表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年03月31日サーバー移管に共に表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年03月30日WordPressの操作方法をサポートいたしました。
  • 2024年03月29日サイドバーに人気記事を表示させる仕組みを導入いたしました。
  • 2024年03月28日テキスト等の簡易な修正を行いました。
  • 2024年03月27日アイキャッチが表示されない不具合を修正いたしました。
  • 2024年03月26日WordPressの操作方法をサポートさせていただきました。
  • 2024年03月25日サイト上で発生していたリンクの不具合を解消いたしました。
  • 2024年03月24日不具合で表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年03月23日WordPress、テーマ、プラグイン、のバージョンアップを担当いたしました。
  • 2024年03月22日WordPressにログインできない不具合を解消いたしました。
  • 2024年03月21日既存サイトにセキュリティ対策を導入いたしました。
  • 2024年03月20日メールフォーム周りで発生していた不具合を解消いたしました。
  • 2024年03月19日記事一覧をカテゴリー単位で表示できる様にカスタマイズいたしました。
  • 2024年03月18日WordPress、テーマ、プラグイン、のバージョンアップを担当いたしました。
  • このエリアには直近の制作実績を一部掲載しております。
  • 制作実績はリアルタイム反映ではありません。

get_the_category()で親子カテゴリーを親子順に表示する方法

この投稿は2019/05/10に加筆修正いたしました。

get_the_category()で親子カテゴリーを親子順に表示する方法をご紹介します。get_the_category()で取得した一覧は、親子カテゴリーが親子順にならない場合があります。今回はその解決方法です。参考にしてください。

この記事は約 5 分で読めます。

今回は、get_the_category()で親子カテゴリーを親子順に表示する方法をご紹介します。

複数のカテゴリが設定されている記事の場合、get_the_category()で全てのカテゴリを一覧で表示することができます。特に問題は発生しません。

しかし、親子カテゴリーが含まれている場合、ちょっとした問題が発生します。

親カテゴリーと子カテゴリーを表示する場合、親⇒子の順番で取得したかと思うのですが、get_the_category()の取得順序は名前順で取得されるため、表示したカテゴリーが親子順にならないケースがしばしば出てくるのです。

残念ながら、デフォルトの状態ではカテゴリの階層順で取得することはできません。

get_the_category()で親子カテゴリーを親子順に表示したい・・・。
そんな場合は、以下で解説するカスタマイズを試してみてください。

get_the_category()で親子順にカテゴリーを取得する方法

get_the_category()で親子順にカテゴリーを取得する方法をご紹介します。
今回は、2パターンのコードをご紹介。

リンクなしで親子順にカテゴリーを取得するコード

リンクなしで親子順にカテゴリーを取得するコード

以下のコードをカテゴリー一覧を取得したい箇所に設置してください。

<ul>
<?php
$cats = $sort = array();
$post_cats = get_the_category();
foreach ($post_cats as $cat) {
$layer = count(get_ancestors($cat->term_id, 'category'));
$cats[] = array(
'name' => $cat->name,
'layer' => $layer
);
$sort[] = $layer;
}
array_multisort($sort, SORT_ASC, $cats);
foreach ($cats as $cat) {
echo '<li>'.$cat['name'].'</li>';
}
?>
</ul>

参考:親、子、孫の順でカテゴリを表示したい

上記のコードを設置した箇所には、以下のようなHTMLが生成されます。

<ul>
<li>カテゴリー名</li>
<li>カテゴリー名</li>
</ul>

親子関係のあるカテゴリーの場合、先に親カテゴリー、次に子カテゴリーが取得されます。

サイト上の見た目は次のようになります。

  • カテゴリー名
  • カテゴリー名

見た目はCSSで調整してください。

リンクありで親子順にカテゴリーを取得するコード

先ほどのコードでは、カテゴリー名がリスト形式で表示されるだけでした。
場合によっては、カテゴリーページへのリンクが必要になるかと思います。

カテゴリーページへのリンクが必要な場合、以下のコードを使ってください。

<ul>
<?php
$cats = $sort = array();
$post_cats = get_the_category();
foreach ($post_cats as $cat) {
$layer = count(get_ancestors($cat->term_id, 'category'));
$cats[] = array(
'name' => $cat->name,
'id' => $cat->term_id,
'layer' => $layer
);
$sort[] = $layer;
}
array_multisort($sort, SORT_ASC, $cats);
foreach ($cats as $cat) {
echo '<li><a href="'.get_category_link( $cat['id'] ).'">'.$cat['name'].'</a></li>';
}
?>
</ul>

参考:親、子、孫の順でカテゴリを表示したい

先ほどのコードと比べると、赤字の部分が異なっている部分です。

上記のコードを設置した箇所には、以下のようなHTMLが生成されます。

<ul>
<li><a href="カテゴリーページのURL">カテゴリー名</a></li>
<li><a href="カテゴリーページのURL">カテゴリー名</a></li>
</ul>

サイト上の見た目は次のようになります。

上記のURLはダミーです。
リンクは動作しておりません。

見た目はCSSで調整してください。

親子順にカテゴリーを表示させる方法の注意点

今回ご紹介したコードは、利用時に注意しておくべき点があります。

ひとつの記事に多くのカテゴリーが設定されている場合、親子カテゴリーの間に別のカテゴリーが割り込んで表示される可能性があるという点です。

例えば、以下のようなカテゴリーがひとつの記事に設定されていたとします。

カテゴリーA(親カテゴリー)
 カテゴリーB(子カテゴリー)
カテゴリーC
カテゴリーD

この場合、以下のような表示になる可能性があります。

  • カテゴリーA(親カテゴリー)
  • カテゴリーC
  • カテゴリーB(子カテゴリー)
  • カテゴリーD

親子カテゴリーの間に、他のカテゴリーが割り込んでしまうんですね。

今回のコードを使う場合は、親子関係のカテゴリーのみが設定されている環境で使うようにしたほうが良いかと思います。

まとめ

get_the_category()で親子カテゴリーを親子順に表示する方法をご紹介しました。

ご紹介しているコードをコピペするだけの簡単なカスタマイズになっています。
get_the_category()で親子カテゴリーを親子順に表示したい場合は試してみてください。

今回の方法は注意事項もありますので、そちらを確認したうえでお試しください。

Wordpressのカスタマイズや不具合など
何かお困りのことはありませんか?

Wordpressに関連するあなたのお悩み、解決いたします。
次のような方は、お気軽にご相談下さい。

  • Wordpressサイトをカスタマイズしたいが、やり方が分からないで困っている。カスタマイズの知識が豊富な人に任せたい。
  • Wordpressサイトに不具合が発生したが、直し方が分からない。不具合の修正経験が豊富な人に任せたい。
  • 既存サイトにWordPressを導入したいが、やり方が複雑で自分ではできそうにもない。経験が豊富な人に任せたい。
  • WordPressがハッキングされたが修正の仕方が分からない。サイトを元通りにできる人を探している。
  • Wordpressで0からサイトを制作したいが、自分ではできそうにもない。プロにサイト制作を委託したい。

一つでも該当する方は、以下のフォームからお気軽にご相談下さい。

WordPressに関して今すぐ相談する

著者:takaya kondo

岡山在住のWordPress専門フリーランサーです。Wordpressを使ったWEBサイト制作を中心に10年間ほど活動させていただいています。

Wordpress関連の記事でお役に立てれば幸いです。

【関連記事】あなたが興味のありそうな関連記事をご紹介します。

コメントを残す

(必須)

CAPTCHA