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

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

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

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

PHP

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

Q&A

解決済

2回答

957閲覧

pre_get_postsでTOPページ(front-page.php)に投稿記事の一覧を表示したいのですが上手く行きません。

tkm0604

総合スコア555

WordPress

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

PHP

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

0グッド

0クリップ

投稿2020/11/18 11:06

編集2020/11/19 13:02

デザインカンプ赤枠の箇所をpre_get_postsを用いてfront-page.phpに表示したいです。
イメージ説明

functions.phpにpre_get_postsをこのようにしています。

PHP

1 function myPreGetPosts( $query ) { 2 if ( is_admin() || ! $query->is_main_query() ){ 3 return; 4} 5 // 指定したページとメインクエリの場合に限定 6 if ( $query->is_front_page() && $query->is_main_query() ) { 7 $query->set( 'post_type', 'post' ); 8 $query->set( 'posts_per_page', '3' ); 9 } 10} 11 12add_action( 'pre_get_posts', 'myPreGetPosts' ); 13コード

そしてfront-page.phpは下記のように書きました。

HTML

1 <div class="blog_area"> 2 <h2 class="blog_notice__title">ブログ</h2> 3 <?php 4 if ( have_posts() ) : while ( have_posts() ) : the_post(); 5 ?> 6 <div class="blog__wrapper"> 7 <?php the_post_thumbnail('thumbnail', array('class' => 'blog__img')); ?> 8 <p class="blog__category"><?php the_category(','); ?></p> 9 <div class="blog_heading"> 10 <?php the_title( '<h2 class="blog__title"><a href="' . esc_url( get_permalink() ) . '">', '</a></h2>' ); ?> 11 <p class="time__date"><?php echo get_the_date(); ?></p> 12 </div> 13 </div> 14 <?php endwhile; //繰り返し処理終了 ?> 15 <?php else : //条件分岐:投稿がない場合は ?> 16 <h2 class="blog__title">投稿が見つかりません。</h2> 17 <?php endif; //条件分岐終了 ?> 18 </div> 19コード

しかし結果は以下の画像のように front-page.phpがループ表示されています。
イメージ説明

pre_get_postsでTOPページ(front-page.php)に投稿記事一覧を表示させるにはどうすれば良いでしょうか? 教えてください。

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

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

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

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

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

guest

回答2

0

pre_get_postsは使わずに mainqueryを使って行うことにしました。

投稿2020/12/12 12:13

tkm0604

総合スコア555

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

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

0

ベストアンサー

is_toppageという関数は(少なくともデフォルトでは)ありません。

【is_home()とis_front_page()の条件分岐タグの違い[WordPress]】
https://noumenon-th.net/programming/2016/06/30/is_home_is_front_page/

投稿2020/11/18 17:37

kei344

総合スコア69606

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

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

tkm0604

2020/11/19 12:51

コメントありがとうございます。 「is_toppageという関数は(少なくともデフォルトでは)ありません。」ということで、TOPページファイル名をfront-page.phpに変更しました。 いただいたリンクを読み、今回のケースはパターン2に当てはまると思いそのようにfunction.phpに記述しましたが、相変わらずループ内にはTOPページ(front-page.php)がループとして表示されたままです。
tkm0604

2020/11/19 13:03

質問内容を簡潔に変更しました。 どこが間違えているのか分からないのでご指摘ください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問