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

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

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

URL(ユニフォームリソースロケータ)とは、インターネット上のリソース(Webページや電子メールの宛先等)を特定するための形式的な記号の並びの事を言う。

WordPress

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

PHP

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

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

Q&A

解決済

2回答

919閲覧

WordPressのメイン投稿がメインループ内で出力されません。

neue

総合スコア1

URL

URL(ユニフォームリソースロケータ)とは、インターネット上のリソース(Webページや電子メールの宛先等)を特定するための形式的な記号の並びの事を言う。

WordPress

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

PHP

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

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

0グッド

0クリップ

投稿2021/08/14 01:36

編集2021/08/14 01:44

初めてWordPressでウェブサイトを作っています。
自分のポートフォリオを載せるため、
single.phpをつかってメイン投稿を作成し、このページ自体はうまく動いているのですが、いざポートフォリオ一覧(portfolio.php)にメイン投稿をループさせようとすると、なぜか一覧の内容が出力されてしまいます...
有識者の方お力添えをお願いいたします...

ポートフォリオ一覧(portfolio.php)のURL:
https://example.com/portfolio-index/
ポートフォリオの詳細として使っているメイン投稿(single.php)のURL:
https://example.com/%postname%/

※煮るに煮詰まって初めて投稿していますので失礼などありましたら申し訳ありません...

portfolio.php内の記述

<?php if (have_posts()): ?> <?php while (have_posts()): the_post(); ?> <!-- ループしたいHTML --> <div class="grid-item"> <a href="<?php the_permalink(); ?>" class="portfolio__item__detail-link"> <?php the_post_thumbnail(null, array(‘class’ => ‘grid-item__img’)); ?> </a> </div> <?php endwhile; else: ?> <div class="no-post__container"> <p class="no-post__text">Coming soon...</p> </div> <?php endif; ?>

###検証で出力される内容

<!-- ループしたいHTML --> <div class="grid-item" style="position: absolute; left: 0px; top: 0px;"> <a href="https://example.com/portfolio-index/" class="portfolio__item__detail-link"></a> </div> </div>

尚、single.phpの冒頭には下記の記述が記入されています。

<?php get_header(); the_post(); //カテゴリーの取得 $cat = get_the_category(); $slug = $cat[0]->slug; $name = $cat[0]->name; // 投稿者ID取得 $user_id = get_the_author_meta('ID');?>

single.php内のアイキャッチ画像なども既に指定しています。
試しにthe titleなどを出力したら、やはりportfolio-indexが表示されたので、
一覧ページの中に一覧ページが出力されてしまっています。
別に作っているカスタム投稿(single-news.php)は別で問題なく出力できました。

何卒アドバイスの程よろしくお願いいたします。

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

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

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

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

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

tabuu

2021/08/15 09:48

>いざポートフォリオ一覧(portfolio.php)にメイン投稿をループさせようとすると、なぜか一覧の内容が出力されてしまいます... どのようにメイン投稿を取得されていますか?
neue

2021/08/15 09:55

すみません… Single.phpに設定した時点でメイン投稿と判断されて <?php if (have_posts()): ?> <?php while (have_posts()): the_post(); ?> を書けば取得されると思ってたのですが… 何か他に必要な記述がありましたでしょうか汗
guest

回答2

0

ベストアンサー

https://example.com/portfolio-index/
は固定ページですかね?

WP_Queryを使ってデータを取得してからループするようにしてください。
ググると解説サイトがたくさんでてきます。

※pre_get_postsをフックしてデータを取得するとテンプレートはそのままで動きますが、難易度は高くなりますのでスキルに合わせて実装方法を選んでください。

投稿2021/08/16 00:30

tabuu

総合スコア2480

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

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

neue

2021/08/16 01:19

WP_Queryで検索して記述追加したらできました!!! どうもありがとうございました涙
guest

0

エラーが出て出力されていないのではないでしょうか。

PHP

1// 全角 ↓ ↓ ↓ ↓ 2the_post_thumbnail(null, array(class=> ‘grid-item__img’));

【WordPress初心者におすすめ!デバッグモードの使い方 | Mignon Style】
https://mignonstyle.com/debug-mode/

投稿2021/08/14 03:02

kei344

総合スコア69606

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

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

neue

2021/08/14 06:52

回答ありがとうございました! 全角になってるとは!見落としてました…が、出力に関しては変わらずでした…
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問