カスタムフィールドの値が空だった場合の条件分岐
MENU
  1. HOME
  2. WordPress / カスタマイズ
  3. カスタムフィールドの値が空だった場合の条件分岐

最近の作業実績

  • 2024年04月06日非レスポンシブのサイトをレスポンシブ化いたしました。
  • 2024年04月05日テーマファイルが編集できない不具合を解消いたしました。
  • 2024年04月04日WordPress、テーマ、プラグイン、のバージョンアップを担当いたしました。
  • 2024年04月03日不具合で表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年04月02日お問い合わせフォームを再構築いたしました。
  • 2024年04月01日不具合で表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年03月31日サーバー移管に共に表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年03月30日WordPressの操作方法をサポートいたしました。
  • 2024年03月29日サイドバーに人気記事を表示させる仕組みを導入いたしました。
  • 2024年03月28日テキスト等の簡易な修正を行いました。
  • 2024年03月27日アイキャッチが表示されない不具合を修正いたしました。
  • 2024年03月26日WordPressの操作方法をサポートさせていただきました。
  • 2024年03月25日サイト上で発生していたリンクの不具合を解消いたしました。
  • 2024年03月24日不具合で表示されなくなったサイトを表示される状態まで復旧いたしました。
  • 2024年03月23日WordPress、テーマ、プラグイン、のバージョンアップを担当いたしました。
  • 2024年03月22日WordPressにログインできない不具合を解消いたしました。
  • 2024年03月21日既存サイトにセキュリティ対策を導入いたしました。
  • 2024年03月20日メールフォーム周りで発生していた不具合を解消いたしました。
  • 2024年03月19日記事一覧をカテゴリー単位で表示できる様にカスタマイズいたしました。
  • 2024年03月18日WordPress、テーマ、プラグイン、のバージョンアップを担当いたしました。
  • このエリアには直近の制作実績を一部掲載しております。
  • 制作実績はリアルタイム反映ではありません。

カスタムフィールドの値が空だった場合の条件分岐

この投稿は2020/05/19に加筆修正いたしました。
2020年5月19日にコードを修正いたしました。

カスタムフィールドで値が入力されていない項目を非表示にする条件分岐をご紹介。カスタムフィールドに値を記入しなくても良い場合など、空白になるそのエリア自体を非表示にしたい時ってありますよね。今回はそんな方法をご紹介しています。
この記事は約 2 分で読めます。

条件分岐を使って項目自体を非表示にする

カスタムフィールドでコンテンツを構成している場合、カスタムフィールドに項目が入力されていない場合でも、その項目自体はサイト上に表示されてしまいます。

<div id="test">
<h2>項目A</h2>
<?php echo post_custom('sample'); ?>
</div>

この場合ですと、カスタムフィールドに値が入力されていないときでも、以下の部分がそのままサイト上に表示されてしまいます。

<div id="test">
<h2>項目A</h2>
</div>

今回は、カスタムフィールドの値が空だった場合、上記の部分も非表示するカスタマイズ方法をご紹介します。

カスタムフィールドの値が空なら非表示、値があれば表示と条件分岐してやれば良いのです。
以下のコードで条件分岐できます。

<?php $value = get_post_meta($post->ID, 'sample', true);?>
<?php if(empty($value)):?>
カスタムフィールド【sample】の値が空の時、ここに記載した内容が表示されます。
<?php else:?>
カスタムフィールド【sample】に値が入っている時、ここに記載した内容が表示されます。
<?php endif;?>

先ほどの例ですと、以下のように記述してやればOkです。

<?php $value = get_post_meta($post->ID, 'sample', true);?>
<?php if(empty($value)):?>
<?php else:?>
<div id="test">
<h2>項目A</h2>
</div>
<?php endif;?>

この様に記述すると【sample】の値が取得できない場合、項目自体を非表示にできます。

sample】の部分には、カスタムフィールド名を記入してください。

まとめ

カスタムフィールドの値が入力されていない項目を非表示にする方法をご紹介しました。

とある案件で必要になったので調べたものをまとめてみました。
今回のコードの様に単純に使えるケースは少ないかと思います。

機会があれば、参考にしてください。

よく使う条件分岐を42種類を以下の記事にまとめてみたのでご確認ください。
【保存版】WordPressの条件分岐を42個まとめてみました!

Wordpressのカスタマイズや不具合など
何かお困りのことはありませんか?

Wordpressに関連するあなたのお悩み、解決いたします。
次のような方は、お気軽にご相談下さい。

  • Wordpressサイトをカスタマイズしたいが、やり方が分からないで困っている。カスタマイズの知識が豊富な人に任せたい。
  • Wordpressサイトに不具合が発生したが、直し方が分からない。不具合の修正経験が豊富な人に任せたい。
  • 既存サイトにWordPressを導入したいが、やり方が複雑で自分ではできそうにもない。経験が豊富な人に任せたい。
  • WordPressがハッキングされたが修正の仕方が分からない。サイトを元通りにできる人を探している。
  • Wordpressで0からサイトを制作したいが、自分ではできそうにもない。プロにサイト制作を委託したい。

一つでも該当する方は、以下のフォームからお気軽にご相談下さい。

WordPressに関して今すぐ相談する

著者:takaya kondo

岡山在住のWordPress専門フリーランサーです。Wordpressを使ったWEBサイト制作を中心に10年間ほど活動させていただいています。

Wordpress関連の記事でお役に立てれば幸いです。

【関連記事】あなたが興味のありそうな関連記事をご紹介します。

コメントを残す

(必須)

CAPTCHA