勉強したことのメモ

webプログラマが勉強したことのメモ。

WordPressにてACFで設定したカスタムフィールドの値を元に記事を並べ替える方法

   

WordPressにてAdvanced Custom Fieldsで設定したカスタムフィールドの値を元に記事のソートしたい。具体的には記事毎にYoutubeのようにGood / Badボタンがあり、Good / Badの多い順で記事をソートしたかった。また、Good / Badの数値が同じ場合は投稿日時でソートしたい。以下に対応方法をメモ。

 

WP_Queryの場合

<?php
$args = array(
    'post_type' => 'post', 
    'paged' => $paged,
    'posts_per_page' =>10,
    'meta_key' => 'good', //ACFで設定するフィールド名を指定
    'orderby' => array(
        'meta_value_num' => 'DESC', //Good順でソート
        'date' => 'DESC', //投稿日時でソート
    ),
);
$my_query = new WP_Query($args);
?>

meta_value_numと指定することでカスタムフィールドを数値としてソートしてくれる。meta_valueだと文字列としてソートされるので注意。

 

$query->setの場合

$query->set('post_type', 'post' );
$query->set('post_status', 'publish');
$metaquery[] = array(
    'meta1' => array(
        'key' => 'good', //ACFで設定するフィールド名を指定
        'type' => 'NUMERIC'
    ),
);
$query->set('meta_query',$metaquery);
$query->set( 'order', 'DESC' );
$query->set('orderby',
    array(
        'meta1' => 'DESC', //Good順にソート
        'date' => 'DESC', //投稿日時でソート
    )
);

 

所感

WP_Queryの方は直感的に分かりやすいが$query->setの方はイマイチよく分からりづらい……。

 - WordPress, CMS

  関連記事

WordPressと別プログラム間でSESSIONが引き継げない

同一サーバ内に自作したプログラムとWordPressを設置しており両者でセッショ ...

VPSにMovableTypeをインストール

VPSにMovableTypeをインストールしたかった。バージョン7系はインスト ...

WordPressで閲覧者にテーマを変更させるプラグイン

「新規サイトを○○みたいなイメージでWordPressのテーマを見繕って欲しい」 ...

WordPressのxmlrpc.phpへの攻撃

サーバーの死活監視をしているシステムから、1つのサイトが落ちているとアラートがき ...

WordPressでデータベース接続確立エラー

WordPressで「データベース接続確立エラー」というエラー表示がされた。大抵 ...

WordPressでテーマの作成

CSSとHTMLコーディングデータがあり、それをWordPressのテーマに反映 ...

WordPressのcron設定で負荷対策

WordPressのcron設定(wp-cron.php)を変更することで負荷が ...

WordPressでスケジュール実行される日時を調べる方法

WordPressであるシステムを実装し、その際に毎日1回スケジュール実行(WP ...

WordPressで固定ページに記事一覧を表示させるプラグイン

WordPressで固定ページ編集時にショートコードを書くことで、記事一覧を表示 ...

WordPressのパーマリンクについて

WordPressのパーマリンクについて、思ったことなんだけど、 ・URLに日本 ...