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

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

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

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

PHP

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

Q&A

解決済

1回答

848閲覧

wordpressのカテゴリの投稿一覧がうまく表示できない。ページネーションを用いて表示できるようにしたい。

of_the_Europa

総合スコア66

WordPress

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

PHP

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

0グッド

0クリップ

投稿2022/05/01 14:00

まずここで言うところのカテゴリは、親カテゴリに属する子カテゴリの投稿一覧を表示させたいのです。

イメージ説明

ちょっとわかりずらいので上の図で表すと、「カテゴリー壱」という親カテゴリに属している「いろはにほへと」「ちりぬるを」「わかよたれそ」などの子カテゴリの記事全部を「カテゴリー壱」のページで、ページネーションで区切って表示させたいのです。

しかし、下記のコードで出力させようとすると、該当のカテゴリとは関係なくサイトの全ての記事が出力されてしまい、またページネーションもうまく機能していない状況でした。

category.php

// category.phpから  // ➀子カテゴリのいる親カテゴリ // ➁子カテゴリのいない親カテゴリ // ➂子カテゴリ // ➃term_id=17の個別のカテゴリ // という感じに別けてからそれぞれのテンプレートファイルで記事一覧を出力させています <?php get_header(); ?> <?php $category = get_the_category(); $cat_now = $category[0]; $slug = $cat_now->slug; $term_id = $cat_now->term_id; $parent_id = $cat_now->parent; // $slug, $term_id, $parent_id これらはそれぞれのテンプレートファイル内でWP_Queryの配列の中にセットしたものです。 $obj = get_queried_object(); $children = get_term_children($parent_id, 'category'); if($obj && $obj->parent === 0 && !empty($children)): include(TEMPLATEPATH . '/category-parent.php'); elseif($obj && $obj->parent === 0 && empty($children) && $term_id != 17): include(TEMPLATEPATH . '/category-notChild.php'); elseif($term_id == 17): include(TEMPLATEPATH . '/category-life.php'); else: include(TEMPLATEPATH . '/category-child.php'); endif; ?> <?php get_footer(); ?>

category-parent.php

// 前省略 <div class="content__catInfo d-flex"> <div class="row"> <?php $paged = (get_query_var('paged')) ? get_query_var('paged') : 1; $args = array( 'post_type' => 'post', 'category' => $parent_id, 'orderby' => 'date', 'order' => 'DESC', 'posts_per_page' => 4, 'paged' => $paged ); $cat_posts = new WP_Query($args); if($cat_posts->have_posts()): while($cat_posts->have_posts()): $cat_posts->the_post(); ?> <article> <a href="<?php the_permalink(); ?>"> <?php if(has_post_thumbnail()): ?> <?php the_post_thumbnail(); ?> <?php else: ?> <img src="<?php echo get_template_directory_uri(); ?>/images/no-image.png"/> <?php endif; ?> <h2 class="content__catInfo__h2 text-left"><?php the_title(); ?></h2> </a> <span><i class="fa fa-clock-o" aria-hidden="true"></i><time><?php the_time('Y/m/d') ?></time></span> </article> <?php endwhile; endif; ?> <?php wp_reset_postdata(); ?> </div> </div> <?php the_posts_pagination( array( 'mide_size' => 5, 'prev_next' => true, 'prev_text' => __('<i class="fa-solid fa-angle-left"></i>'), 'next_text' => __('<i class="fa-solid fa-angle-right"></i>'), 'type' => 'list', 'total' => $cat_posts->max_num_pages ) ); ?> // 後省略

この記述になる以前は、WP_Queryを使わずget_posts()で希望の一覧は表示できていたのですが、ページネーションを使うにあたり max_num_pages の指定が必要だったため仕方なくWP_Queryを使うことにしました。しかしその結果、思うような記事一覧ではなくなってしまいました。

他に調べてみたのですが、functions.phpで別にページネーション関数を設定しているところを見かけたりするのですが、正直カテゴリーの記事一覧で使用するのに、それが正しいのかよくわかりませんでした。
カテゴリーページでも the_posts_pagination() は使えると認識しているのですが、それもこの場面で使えるかは正直自信がないです。
その点の理解も不十分でしたので、質問させていただきました。

何卒宜しくお願い致します。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自己解決いたしました。
と、同時に解答がいただけなかった理由もわかったような気がします。

その理由としては、特定のカテゴリの記事一覧ページを表示させるのに、
質問のcategory.phpとcategory-parent.phpのコードだけでは説明が足りていないのに気付いたからです。それぞれのカテゴリページにリンク張りつけたsidebar.phpも表記させるべきでした。

ですので、sidebar.php のコードを遅ればせながら、こちらに表記させていただきます。

<div class="side"> <div class="side-1"> <h4 class="p-3 side-1__title">カテゴリー</h4> <?php echo '<ul class="side-1__parent">'; $args = array( 'parent' => 0 ); $parent_categories = get_categories($args); foreach($parent_categories as $parent_category){ echo '<li>'. $parent_category->description . '<a href="' . esc_url(get_category_link($parent_category->term_id)) .'">' . $parent_category->name . '</a>'; $args = array( 'parent' => $parent_category->term_id ); $children_categories = get_categories($args); if($children_categories != ''){ echo '<ul class="side-1__children">'; foreach($children_categories as $children_category){ echo '<li class="children__li"><a href="' . esc_url(get_category_link($children_category->term_id)) . '" class="children__a">' . $children_category->name . '</a></li>'; } echo '</ul>'; } echo '</li>'; } echo '</ul>'; ?> </div> // 以下省略

その上で本題の自己解決なのですが、
➀ category-parent.phpではメインループにしました。

<?php   if(have_posts()): while(have_posts()): the_post(); ?> // 中省略 <?php my_paginate(); ?> <?php wp_reset_postdata(); ?>

➁ そしてfunctions.phpに上記のmy_paginate関数を定義します。この中にグローバル変数の $wp_query と $paged を使ってページの総数と現在のページ番号を取得します。

function my_paginate(){ global $wp_query, $paged; echo the_posts_pagination( array( 'mide_size' => 5, 'prev_next' => true, 'prev_text' => __('<i class="fa-solid fa-angle-left"></i>'), 'next_text' => __('<i class="fa-solid fa-angle-right"></i>'), 'type' => 'list', 'total' => $wp_query->max_num_pages, 'current' => ($paged ? $paged : 1) ) ); }

➂ posts_per_pageは設定していませんが、管理画面の表示設定からでもそれはできるので、今回その点は良しとしています。

質問から自己解決まで長々と説明したので、そもそも読み飽きてしまうかもしれませんが、どなたかのお役に立てれば幸いです。

投稿2022/05/03 13:54

of_the_Europa

総合スコア66

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問