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

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

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

foreachは、List・Collection・Arrayといったデータ構造の各要素に対して繰り返し処理を実行するために扱われる、制御構造の構文です。

if

if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

WordPress

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

PHP

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

Q&A

解決済

1回答

5513閲覧

php if 分岐+foreach処理でforeachの2回目以降からifが効かない

nats

総合スコア22

foreach

foreachは、List・Collection・Arrayといったデータ構造の各要素に対して繰り返し処理を実行するために扱われる、制御構造の構文です。

if

if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

WordPress

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

PHP

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

0グッド

0クリップ

投稿2018/04/22 13:42

編集2018/04/22 13:43

WP_Queryを用いてAdvanced Custom Fieldsプラグインのデータを抽出してリストした際、
画像カスタムフィールド「flyimg」が有る場合と無い場合で以下内容で分岐をしたいです。

有る場合は画像を配置。
無い場合の処理はカスタムフィールド 「artists」の画像を上限4枚並べるという内容で以下の構文を書きました。

4枚の画像を並べる方法はforeachを用いておりますが、
foreachが一度行われた後のループが、「flyimg」がある記事もforeachの内容が適応されてしまい、
解決策を見つける事ができず困っております。

前提として、「flyimg」の有無かかわらず、
検索対象記事に全てに「artists」の項目が入力されています。

1度目のforeachが行われる前までは、「flyimg」 trueの処理を行ってくれます。
foreachの記事が一番目に有る場合は、全ての結果がforeach内の処理となってしまいます。

<?php $currnet_date = date_i18n( 'y/m/d' ); $args = array( 'posts_per_page' => 10, 'order' => 'DESC', 'meta_key' => 'pickup', 'meta_value' => true, 'meta_query' => array( 'relation' => 'AND', array( 'key' => 'e-date', 'value' => $currnet_date, 'compare' => '>=', 'type' => 'DATE' ) ) ); $my_query = new WP_Query($args); if ($my_query->have_posts()) : while ($my_query->have_posts()) : $my_query->the_post();  $FlyImg = get_field('flyimg',$value->ID); ?> <?php if($FlyImg):?> <img class="img-fluid" src="<?php echo $Aimg; ?>" /> <?php else: ?> <?php $artists = get_field('artist'); ?> <?php if($artists): ?> <div class="row no-gutters"> <?php $count = 0 ;?> <?php foreach((array)$artists as $value):?> <?php if($count >= 4){ break; } ?> <div class="col-6"> <img class="img-fluid" src="<?php echo $Bimg; ?>" /> </div> <?php $count++; ?> <?php endforeach; ?> </div> <?php wp_reset_postdata();?> <?php endif; ?> <?php endif;?>

助言いただければ幸いです。何卒宜しくお願い申し上げます。

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

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

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

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

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

m.ts10806

2018/04/23 01:03 編集

while がどこで閉じられているか分かりづらいのでインデントを整理していただきたいのですが・・・ ifもendif使ってたり}で閉じてたりで統一性がないので、そこも整理していただきたいです。
guest

回答1

0

ベストアンサー

php

1$FlyImg = get_field('flyimg',$value->ID);

そりゃまあ、毎回同じ投稿のflyimgの
空白判定してるわけですから
そうなるでしょうね

$value->ID←これ、要らないんじゃないですか?

投稿2018/04/23 02:06

KazuhiroHatano

総合スコア7804

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

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

nats

2018/04/23 02:12

ご回答ありがとうございます!こちら削除したら問題が解決しました。 まだまだphpの初歩も理解できておらず、色々なページを参考にソースを組んでおりますので、無駄な処理を行ってたみたいです。本当にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問