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

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

ただいまの
回答率

89.11%

記事一覧で月の見出しをつける

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 554

juska

score 15

 前提・実現したいこと

投稿記事一覧に月の見出しを付け、ソートしたいと思っています。
参考サイト[https://hirashimatakumi.com/blog/3351.html](URL)

目的のページは「コンサートの一覧表」を表示したいと思っており、
月の見出しは「投稿日」ではなく、カスタムフィールドで入力した「公演日」を参照し、
ソートもカスタムフィールドの「公演日」で並べ替えたいと思っています。
※カスタムフィールド名 concert_date ※YMdで表示されてる? ※ACFでカスタムフィールド作成

参考サイト内のコード

<?php // 投稿一覧に年と月の見出しを付ける
$args = array(
'post_type' => 'news', // 任意のカスタム投稿タイプを指定
'posts_per_page' => -1, // 1ページに表示する最大投稿数を指定、-1は全てを表示
'order' => 'DESC', // 降順でソート
'orderby'=>'date' // 日付で並べる
);
$the_query = new WP_Query($args);
if($the_query->have_posts()):
$post_year = false; // 年の比較用変数の初期化
$post_month = false; // 月の比較用変数の初期化
echo '<h1>投稿一覧</h1>';
while ($the_query->have_posts()): $the_query->the_post();
if( $post_month != get_post_time('n') ) { // 比較の値と投稿月が異なる場合に以下を表示
if ( $post_month !== false ) { // 比較の値と投稿月が異なる場合に以下を表示
echo '</ul>';
}
if ( $post_year != get_post_time('Y') ) { // 比較の値と投稿年が異なる場合に年を表示
echo '<h2>'.get_post_time('Y年').'</h2>'; //投稿の年を表示
}
echo '<h3>'.get_post_time('n月').'</h3>'; //投稿の月を表示
echo '<ul>';
}
echo '<li><a href="'.get_the_permalink().'">'.get_the_title().'</a></li>'; // 投稿のリンクとタイトルを表示
$post_year = get_post_time('Y'); // 年月の比較用の変数に今の投稿の年月を代入
$post_month = get_post_time('n'); // 年月の比較用の変数に今の投稿の年月を代入
endwhile;
wp_reset_postdata();
echo '</ul>';
endif;
?>

<?php // 投稿一覧に年と月の見出しを付ける
$args = array(
'post_type' => 'post', // 任意のカスタム投稿タイプを指定
'posts_per_page' => -1, // 1ページに表示する最大投稿数を指定、-1は全てを表示
'meta_key'            => 'concert_date',
    'orderby'            => 'meta_value',
    'order'                => 'DESC'
);
$the_query = new WP_Query($args);
if($the_query->have_posts()):
$post_year = false; // 年の比較用変数の初期化
$post_month = false; // 月の比較用変数の初期化
echo '<h1>投稿一覧</h1>';
while ($the_query->have_posts()): $the_query->the_post();
if( $post_month != get_post_time('n') ) { // 比較の値と投稿月が異なる場合に以下を表示
if ( $post_month !== false ) { // 比較の値と投稿月が異なる場合に以下を表示
echo '</ul>';
}
if ( $post_year != get_post_time('Y') ) { // 比較の値と投稿年が異なる場合に年を表示
echo '<h2>'.get_post_time('Y年').'</h2>'; //投稿の年を表示
}
echo '<h3>'.get_post_time('n月').'</h3>'; //投稿の月を表示
echo '<ul>';
}
echo '<li><a href="'.get_the_permalink().'">'.get_the_title().'</a></li>'; // 投稿のリンクとタイトルを表示
$post_year = get_post_time('Y'); // 年月の比較用の変数に今の投稿の年月を代入
$post_month = get_post_time('n'); // 年月の比較用の変数に今の投稿の年月を代入
endwhile;
wp_reset_postdata();
echo '</ul>';
endif;
?>

として、日付でのソートは可能となりましたが、見出しが出てきません。

.get_post_timeなどを修正すればいいと考えていましが、表示がうまくいかず、
どうやったらカスタムフィールドの「公演日」の「年」「月」をひっぱてこれるのか悩んでおります。

アドバイスいただけますと幸いです。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

ACFの値の取得には

$変数 = get_field('カスタムフィールド名');


を使用します。

そのまま表示させたい場合は

the_field('カスタムフィールド名');


で済みます。

今回の場合ですと

get_post_time();


の部分を変更されればいいのではないかと思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/10/16 12:24

    早速のご回答ありがとうございます!

    追加でお聞きしたいのですが、

    get_post_time();



    the_field(''concret_date);  ※concert_dateはカスタムフィールド名

    とした場合、
    既存コードにある('Y')の扱いはどうなるのでしょうか。

    キャンセル

  • 2018/10/16 14:31

    $date = get_field('date', false, false); //値の取得
    $date = new DateTime($date); //日付オブジェクトの作成
    echo $date->format('j M Y'); //日付の表示

    これで日付のフォーマットは設定できると思います。

    キャンセル

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

  • ただいまの回答率 89.11%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる