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

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

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

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

PHP

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

Q&A

解決済

1回答

572閲覧

ループ中にカスタムフィールドが入力されているかで条件分岐したいです。

makoto-n

総合スコア436

WordPress

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

PHP

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

0グッド

0クリップ

投稿2019/07/15 14:58

編集2019/07/16 10:13

前提・実現したいこと

ループ中に投稿のカスタムフィールドが入力されているかで条件分岐したいです。

発生している問題・エラーメッセージ

何も表示されないです。

該当のソースコード

念の為functions.phpも書きます

php

1 <?php if (have_posts()) : ?> 2 <div> 3 <?php global $post; 4 $args = array( 5 'posts_per_page' => 10 6 ); 7 $myposts = get_posts( $args ); 8 foreach ( $myposts as $post ) : setup_postdata( $post ); ?> 9 <section class="post"> 10 <?php 11 if if(!get_post_meta($post->ID, 'img', true)) { 12 // カスタムフィールド判別 13 the_post_thumbnail('post-thumbnail'); 14 } else { 15 echo "<img src=" .get_post_meta($post->ID, "img", true). ">"; 16 } ?> 17 <div class="post-title"> 18 <h3><a href="<?php the_permalink() ?>"><?php the_title(); ?></a></h3> 19 </div> 20 </section> 21 <?php endforeach; ?> 22 </div> 23 <?php else: endif; ?>

functions.php

php

1 // 固定カスタムフィールドボックス 2 function add_url_fields() { 3 add_meta_box( 'custom_meta_setting', 'img', 'insert_meta_fields', 'post', 'normal'); 4 } 5 add_action('admin_menu', 'add_url_fields'); 6 7 // カスタムフィールドの入力エリア 8 function insert_meta_fields() { 9 global $post; 10 echo '<input type="text" name="img" value="'.get_post_meta($post->ID, 'img', true).'" size="50" /><br>'; 11 } 12 13 // カスタムフィールドの値を保存 14 function save_meta_fields( $post_id ) { 15 if(!empty($_POST['img'])){ 16 update_post_meta($post_id, 'img', $_POST['img'] ); 17 }else{ 18 delete_post_meta($post_id, 'img'); 19 } 20 } 21 add_action('save_post', 'save_meta_fields'); 22

修正テキスト
functions.phpに記載

php

1 // small_thum_chk 2 function small_thum_chk() { 3 if ( get_post_meta($post->ID, 'img', true) ){ 4 $thumb = '<img src='.get_post_meta($post->ID, 'img', true).'>'; 5 } elseif ( has_post_thumbnail() ) { 6 $thumb = the_post_thumbnail( 'small_thumbnail', array('title' => get_the_title()) ); 7 } else { 8 $thumb = '<img src="https://placehold.jp/eee/aaa/64x64.jpg?text=no-img">'; 9 } 10 echo $thumb; 11 }

small_thum_chk()を呼び出した際にのみカスタムフィールドに記載されているURLを記述したimgタグを挿入できるようにしたいです。
発生している事象ですが,
if ( get_post_meta($post->ID, 'img', true) )を認識せず、

php

1elseif ( has_post_thumbnail() ) { 2 $thumb = the_post_thumbnail( 'small_thumbnail', array('title' => get_the_title()) ); 3}

のみ読み込んでいます。
imgのカスタムフィールドは記述しています。

追記

php

1 <?php if (have_posts()) : ?> 2 <section class="sidebar_area"> 3 <p>最近の投稿</p> 4 <?php global $post; 5 $args = array( 6 'posts_per_page' => 4 7 ); 8 $myposts = get_posts( $args ); 9 foreach ( $myposts as $post ) : setup_postdata( $post ); ?> 10 <div class="sidebar_post clearfix"> 11 <a href="<?php the_permalink() ?>" class="float-left"><?php small_thum_chk(); ?></a> 12 <h4 class="float-left"><a href="<?php the_permalink() ?>"><?php the_title(); ?></a></h4> 13 </div> 14 <?php endforeach; ?> 15 </section> 16 <?php else: endif; ?>

functions.php

php

1 // small_thum_chk 2 function small_thum_chk() { 3 if ( get_post_meta($post->ID, 'img', true) ){ 4 $thumb = '<img src='.get_post_meta($post->ID, 'img', true).'>'; 5 } elseif ( has_post_thumbnail() ) { 6 $thumb = the_post_thumbnail( 'small_thumbnail', array('title' => get_the_title()) ); 7 } else { 8 $thumb = '<img src="https://placehold.jp/eee/aaa/64x64.jpg?text=no-img">'; 9 } 10 echo $thumb; 11 }

if ( get_post_meta($post->ID, 'img', true) )がtrueになりません。


表示箇所のスクリーンショット
イメージ説明

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

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

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

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

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

guest

回答1

0

ベストアンサー

PHP

1 if if(!get_post_meta($post->ID, 'img', true)) {

ifが重複してます。

投稿2019/07/15 20:39

yukikp

総合スコア797

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

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

makoto-n

2019/07/16 08:28

回答ありがとうございます。 ifの重複気づきませんでした。 けれど、編集してもカスタムフィールドを挿入できません。 修正を本文に追記します。
yukikp

2019/07/16 08:43

よく見たら、 <?php if (have_posts()) : ?> <div> <?php global $post; ここら辺ですね。このif( have_posts() ): endif; と、 global $post; を消してみてください。
yukikp

2019/07/16 08:49

<?php if (have_posts()) : ?> これって、WordPressが、urlから自動的に判断してデータベースから取ってきたデータの判定しているのですが、あなたの場合、WordPressが自動的に準備したデータは使わず、$argsの条件を元にget_posts()でデータを取得しているので不要です
makoto-n

2019/07/16 09:02

front-pageやサイドバーでそれぞれカテゴリーごとのループを回しています。 なのでそのうちの一つですは <!-- sidebar-foods --> <?php if (have_posts()) : ?> <section class="sidebar_area"> <p>「食材」</p> <?php global $post; $args = array( 'posts_per_page' => 4, 'category_name' => 'foods' ); $myposts = get_posts( $args ); foreach ( $myposts as $post ) : setup_postdata( $post ); ?> と書いていたりもします。
yukikp

2019/07/16 09:38

テンプレートファイルのコードは後で確かめてみますが、small_thumb_chkの方は、 ・has_post_thumbnail()はループ内でしか機能しない ・global $post;が抜けている と言う点で動かないと思います。
yukikp

2019/07/16 09:47

global $post; と、関数の最初で宣言して、その後でhas_post_thumbnail( $post->ID )と引数を与えてあげてみてください。 また、the_post_thumbnail()は、引数に投稿IDに取らないので、ループ以外では使いません。get_the_post_thumbnail()を使ってみてください。使い方は https://wpdocs.osdn.jp/テンプレートタグ/get_the_post_thumbnail こちらから。
makoto-n

2019/07/16 09:50

small_thumb_chk、ループ内でサムネイルを表示・非表示きりわける関数です。 global $postが設定されたループ内で使用し、特に異常は無いのでているのでこの関数自体には問題は無いと思います。
yukikp

2019/07/16 09:50

それと、small_thumb_chk関数って、問題のコードで使ってないようですが、なぜ急に出てきたのでしょう?? 質問と関係あるのでしょうか?
makoto-n

2019/07/16 09:54

最初に記述したphpコードは不適切でした。 なるべく必要最小限にと思ったのですが、 なので使用している箇所のコードをすべて追記します。
yukikp

2019/07/16 09:56

読み返してみると、こちはの質問も散漫で。なんだかいちゃもんつけてるように見えますね。。。 気を悪くされてたらごめんなさい。
makoto-n

2019/07/16 10:00

いえ、こちらの提示したコードが不適切でした。 気を悪くさせてしまい申し訳ないです。
YukiYamashina

2019/07/16 10:03

> global $postが設定されたループ内で使用し、特に異常は無いのでているのでこの関数自体には問題は無いと思います。 グローバル変数の $post を参照するのであれば、どこで呼び出すかに関わらず small_thumb_chk 関数内に global $post; がないと期待通りに動きません。
makoto-n

2019/07/16 10:16

該当箇所のスクリーンショットを追記しました。 function small_thum_chk()は問題なく動いているんです。 if ( get_post_meta($post->ID, 'img', true) )がtrueにならないんです。
YukiYamashina

2019/07/16 10:25 編集

> if ( get_post_meta($post->ID, 'img', true) )がtrueにならないんです。 global $post; を書いていないからです。global $post; を書かないと $post->ID は NULL となり、get_post_meta 関数は false しか返しません。
yukikp

2019/07/16 10:25

まあまあ、そう固いこと言わずに、global $post;を関数内の最初で宣言してみましょ!
makoto-n

2019/07/16 10:28

> $global $post; を書いていないからです。 small_thumb_chk()内に記述したところ反映できました! 呼び出し元で記述しているなら大丈夫と思っていました... ありがとうございます。
yukikp

2019/07/16 10:31

よかったですね〜
makoto-n

2019/07/16 10:36

お二方本当にありがとうございました。 質問も理解も未熟で申し訳なかったです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問