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

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

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

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

Q&A

解決済

1回答

1702閲覧

「Advanced Custom Fields」のデイトピッカーの出力(日付フォーマット)が指定通りにいきません。

fuwafuwacocoa

総合スコア5

WordPress

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

0グッド

0クリップ

投稿2020/01/08 03:05

初めて質問させていただきます。
WordPressは何年もカスタマイズしていますが、PHPの記述を自ら生み出せるわけではないので、いつも検索してやっとやりたいことを実現させている感じのレベルです。
アドバイスいただけると嬉しいです。よろしくお願いいたします。

前提・実現したいこと

WordPressのトップページに、開催予定・開催中のイベント情報を2件掲載したいと思っております。

設定項目は以下になります。

  • 表示したいイベント情報は「投稿」のカテゴリ「イベント」で投稿しています。
  • 開催日は「Advanced Custom Fields」で「app_end」というフィールド名をつけ、デイトピッカーで日付を設定。
  • デイトピッカーの「表示フォーマット」と「返り値のフォーマット」はCustomで「Y/m/d」を設定。

発生している問題

開催日を「Y/m/d」の形式で表示させたいのですが、「20200110」というように表示されてしまいます。
※開催予定・開催中の表示非表示はうまくいっています。

該当のソースコード

コードは、検索して出てきた使えそうなコードを拝借しました。

php

1 <?php 2 $current_date = date_i18n( 'Y/m/d' ); 3 $args = array( 4 'showposts' => '2', 5 'orderby' => 'meta_value', 6 'meta_key' => 'app_end', 7 'order' =>'ASC', 8 'meta_query' => array( 9 array( 10 'key' => 'app_end', 11 'value' => $current_date, 12 'compare' => '>=', 13 'type' => 'DATE' 14 ) 15 ) 16 ); 17 $output = ''; 18 query_posts( $args ); 19 if ( have_posts() ) : 20 $output .= ' 21 <div class="event-area area-wrap"> 22 <h2 class="pagettl__head">イベント・アクションに参加する</h2> 23 <div class="container-sm inner">'; 24 while ( have_posts() ) : the_post(); 25 $output .= ' 26<div class="box"><div class="date"><span><i class="fa fa-calendar" aria-hidden="true"></i> 開催日</span><span>'. get_post_meta( $post->ID, 'app_end', true ) .'</span></div> 27<h3 class="ttl"><a href="'. get_permalink() .'">'. get_the_title() .'</a></h3></div> 28'; 29 endwhile; 30 $output .= '</div></div> 31'; 32 echo $output; 33 wp_reset_query(); 34 endif; 35 ?>

試したこと

  • WordPressの「設定>一般」で「日付のフォーマット」を「Y/m/d」に変更してみるも何も変わらず。
  • get_post_meta( $post->ID, 'app_end', true )the_field('app_end')などにしてみるも、うまくいかず。そもそも記述方法が合っていないですよね。。

補足情報(ツールのバージョンなど)

  • WordPressのバージョン:5.3.29
  • 「Advanced Custom Fields」のバージョン:5.8.7(最新)

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

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

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

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

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

guest

回答1

0

ベストアンサー

返り値のフォーマットY/m/dになっていて出力方法がthe_field('メタキー')get_field('メタキー')ならY/m/dになりますがget_post_meta()だとデータベースに保存された値を返すだけです。
the_fieldY/m/dにならないなら返り値のフォーマットY/m/dになっていないと思われます。

<?php $current_date = date_i18n( 'Y/m/d' ); $args = array( 'showposts' => '2', 'orderby' => 'meta_value', 'meta_key' => 'app_end', 'order' =>'ASC', 'meta_query' => array( array( 'key' => 'app_end', 'value' => $current_date, 'compare' => '>=', 'type' => 'DATE' ) ) ); $the_query = new WP_Query( $args ); if ( $the_query->have_posts() ): ?> <div class="event-area area-wrap"> <h2 class="pagettl__head">イベント・アクションに参加する</h2> <div class="container-sm inner"> <?php while ( $the_query->have_posts() ): $the_query->the_post(); ?> <div class="box"> <div class="date"> <span><i class="fa fa-calendar" aria-hidden="true"></i>開催日</span><span><?php the_field( 'app_end' ); ?></span> <h3 class="ttl"><a href=<?php echo get_permalink(); ?>"><?php the_title(); ?></a></h3> </div> </div> <?php endwhile; wp_reset_postdata(); ?> </div></div> <?php endif; ?>

投稿2020/01/08 03:42

編集2020/01/08 08:34
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

fuwafuwacocoa

2020/01/08 04:44

早速ありがとうございます。 「the_field」や「get_field」で出力しないと「Y/m/d」形式で表示されないのですね。 今の記述方法だと、ちょっと厳しそうなので別の方法でやってみます。
退会済みユーザー

退会済みユーザー

2020/01/08 08:34

厳しそうですか?get_post_metaの所を書き換えれば済む話しです。 でもquery_postsとか使わない方がいいです。 ネットに書かれている情報も古いまま訂正もされないものも多いので参考にするならなるべく新しい情報から選んでください。 適当に書き換えて回答に追記したのでおかしかったら直してください。
fuwafuwacocoa

2020/01/08 13:54

表示されました!感動です!!>< 教えていただいたコードを見ても、恥ずかしながらサッパリで…。。 query_postsも使わない方がいいとはわかっているのですが、どうにもいかないとついそのまま使ってしまい; 教えていただいたコードを理解できるよう、これからがんばります。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問