質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.77%

  • PHP

    19231questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • WordPress

    6677questions

    WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

多階層のカテゴリ一覧と投稿一覧を表示させたい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 493
退会済みユーザー

退会済みユーザー

前提・実現したいこと

お世話になっております。
表題の件について、現在のカテゴリ情報の一覧と投稿一覧を表示させたく質問しました。
参考サイトのコードですと、現在のページからではなく、全カテゴリの一覧と投稿記事が表示されてしまい、4階層目・5階層目のカテゴリが表示できないため少しコードを加えてみましたが上手く出来ません。。(コードも汚いです)
カテゴリだけ表示させるならwp_list_categoriesを使えば良かったのですが、最下層のカテゴリを表示させたいのでその記述方法についても教えて頂ければ幸いです。

WordPress タームの親・子・孫の一覧に孫タームの投稿一覧を表示する方法
ワードプレスで3階層までカテゴリを固定ページテンプレートで表示

表示させたいこと

  <section>
  <h1><span>親カテゴリタイトル</span></h1>

  <h2>子カテゴリA_タイトル(2階層目)</h2>

  <h2>子カテゴリB_タイトル(2階層目)</h2>
  <h3 class="cat-item category-child-three">孫カテゴリA_タイトル(3階層目)</h3>
  <h3 class="cat-item category-child-three">孫カテゴリB_タイトル(3階層目)</h3>
  <h4 class="category-child-four">4階層目カテゴリA_タイトル</h4>
  <h4 class="category-child-four">4階層目カテゴリB_タイトル</h4>
  <h5 class="category-child-five">5階層目カテゴリA_タイトル</h5>
  <!-- 5階層目カテゴリに紐づく投稿一覧 -->
  <div class="bottom_layer">
    <ul class="post_list">
      <li><a href="#">投稿タイトル</a></li>
      <li><a href="#">投稿タイトル</a></li>
      <li><a href="#">投稿タイトル</a></li>
      <li><a href="#">投稿タイトル</a></li>
    </ul>
  </div>
</section>

試したこと(まだカテゴリ表示のみ)

<section>
<?php 
$children = get_the_category($post->ID,'category');
$current_cats = get_queried_object();
?>
<?php if($children) : ?>
<?php
$cats_id = get_category_by_slug($category_name)->term_id;
$args = array('orderby' => 'name', 'order' => 'ASC','child_of' => $current_cats->term_id );
$categories = get_categories($args); ?>
<h1><span><?php single_cat_title(); ?></span></h1>
<?php foreach($categories as $category){
   echo '<h2>' . $category->name . '</h2>';

        // 第3階層
        $category_ids = get_term_children($category->cat_ID,'category');
        $category_counts = count($category_ids);
        $children_args = array('parent'=>$category->cat_ID);
        $child_category_objects = get_categories($children_args);
        $child_category_objects_pointer = $child_category_objects;
        if($category_counts > 0){
          foreach($child_category_objects as $child_category_object){
            $child_category_id = $child_category_object -> cat_ID;
            echo '<h3 class="cat-item category-child-three">' . $child_category_object -> name .'</h3>';

            // 第4階層
            $grandson_categories_ids = $child_category_object -> cat_ID;
            $grandson_categories_name = $child_category_object -> name;
            $grandson_categories_count = count(get_term_children($grandson_categories_ids,'category'));
            if($grandson_categories_count > 0){
              $grandson_category_args = array('parent'=>$grandson_categories_ids);
              $grandson_category_objects = get_categories($grandson_category_args);
              $grandson_category_objects_pointer = $grandson_category_objects;
              foreach($grandson_category_objects as $grandson_category_object){
                echo '<h4 class="category-child-four">' . $grandson_category_object -> name . '</h4>';

                // 第5階層
                $greatgrandson_categories_ids = $grandson_category_object -> cat_ID;
                $greatgrandson_categories_name = $grandson_category_object -> name;
                $greatgrandson_categories_count = count(get_term_children($greatgrandson_categories_ids,'category'));
                if($greatgrandson_categories_count > 0){
                  $greatgrandson_category_args = array('parent'=>$greatgrandson_categories_ids);
                  $greatgrandson_category_objects = get_categories($greatgrandson_category_args);
                  $greatgrandson_category_objects_pointer = $greatgrandson_category_objects;
                  foreach($greatgrandson_category_objects as $greatgrandson_category_object){
                    echo '<h5 class="category-child-five">' . $greatgrandson_category_object -> name . '</h5>';
                  }
                }
              }
            }
          }
        } 
} ?>
 <?php endif; ?>
</section>

出力結果(◎があるとこは重複してます)

<section>
  <h1><span>親カテゴリタイトル</span></h1>

  <h2>子カテゴリA_タイトル(2階層目)</h2>

  <h2>子カテゴリB_タイトル(2階層目)</h2>
  <h3 class="cat-item category-child-three">孫カテゴリA_タイトル(3階層目)</h3>
  <h3 class="cat-item category-child-three">孫カテゴリB_タイトル(3階層目)</h3>
  <h4 class="category-child-four">4階層目カテゴリA_タイトル</h4>
  <h4 class="category-child-four">4階層目カテゴリB_タイトル</h4>
  <h5 class="category-child-five">5階層目カテゴリA_タイトル</h5>
  <h2>孫カテゴリA_タイトル(3階層目)</h2><h2>孫カテゴリB_タイトル(3階層目)</h2><h3 class="cat-item category-child-three">4階層目カテゴリA_タイトル</h3><h3 class="cat-item category-child-three">4階層目カテゴリB_タイトル</h3><h4 class="category-child-four">5階層目カテゴリA_タイトル</h4><h2>4階層目カテゴリA_タイトル</h2><h2>4階層目カテゴリB_タイトル</h2><h3 class="cat-item category-child-three">5階層目カテゴリA_タイトル</h3></section>

カテゴリ

親カテゴリ
 ├子カテゴリA
 └子カテゴリB
   ├孫カテゴリA
   └孫カテゴリB
     ├4階層目カテゴリA
     └4階層目カテゴリB
       └5階層目カテゴリA

追記

テンプレートはcategory.phpになります。
今現状のコードはまだカテゴリを表示させている段階で、投稿一覧を表示させるのには参考サイトのコードでもいいかなと考えていますが、コードが汚いのでもう少し簡潔に記述できる方法がありますでしょうか…?
お力添えをいただければ幸いです。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • 退会済みユーザー

    退会済みユーザー

    2017/10/15 18:33

    どのテンプレートで表示させようとしてますか?

    キャンセル

  • 退会済みユーザー

    退会済みユーザー

    2017/10/15 18:56

    category.phpに表示させようとしています。

    キャンセル

回答 1

checkベストアンサー

+1

child_of ではなく parent では?

【get_categories:WordPress私的マニュアル】
https://elearn.jp/wpman/function/get_categories.html

child_of    カテゴリーのIDを指定(そのIDのカテゴリーの子孫がすべて対象となる)
parent    カテゴリーのIDを指定(そのIDのカテゴリーの子カテゴリーのみが対象となる)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/15 19:12

    ご回答いただきありがとうございます。
    パラメータの認識が甘かったようですね…。
    一度検証をしてみます。

    キャンセル

  • 2017/10/23 22:18 編集

    お返事が遅くなってしまい申し訳ございません。
    検証してみた結果parentで重複していたところは改善できました。
    ありがとうございます。

    キャンセル

  • 2017/10/24 04:13

    あとはなにがわからないのでしょうか?

    キャンセル

  • 2017/10/24 08:48

    追記したのですが、今のコードだと無駄な記述があるような気がしてもう少し簡潔にできる方法がないのかと考えています。

    キャンセル

  • 2017/10/24 11:12

    使っていない変数を整理したり、get_term_childrenと次に出てくるget_categoriesは同じ結果を返すので整理したりするくらいじゃないですか?

    キャンセル

  • 2017/10/25 16:33

    To: マイナス評価をされた方へ
    どのあたりに問題があるか、コメントを残すようにしてください。何についてのマイナスかがこちらにはわかりませんし、もし問題がある場合修正することも出来ません。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.77%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    19231questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • WordPress

    6677questions

    WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。