Wordpressのカスタムフィールドにカンマで区切った複数の値があります。
カスタムフィールドを一覧表示させた際に複数の値がカンマで区切ったまま表示されるのを
別々に表示させる事は可能でしょうか?
single.php
<?php $url = site_url(); // url取得 $list = get_meta_values('hoge'); // カスタムフィールド取得 shuffle($list); foreach ( $list as $key=>$value) { $list_name[$key] = $value->name; echo '<li><a href='. $url . '/meta?key=hoge&value=' . $value->name . '>' . $value->name . '</a></li>'; } ?>
上記の$value->nameをダンプすると下記が表示されます。
array(8) { [0]=> object(stdClass)#2971 (2) { ["name"]=> string(42) "柴犬,チワワ,ポメラニアン,パグ" ["count"]=> string(1) "1" } [1]=> object(stdClass)#2970 (2) { ["name"]=> string(46) "柴犬,ボクサー,パグ,プードル,ゴールデンレトリバー" ["count"]=> string(1) "1" } [2]=> object(stdClass)#2915 (2) { ["name"]=> string(9) "チワワ" ["count"]=> string(1) "1" } [3]=> object(stdClass)#2927 (2) { ["name"]=> string(35) "チワワ,ポメラニアン,柴犬" ["count"]=> string(1) "1" } [4]=> object(stdClass)#2923 (2) { ["name"]=> string(9) "ダックスフント" ["count"]=> string(1) "1" } [5]=> object(stdClass)#2921 (2) { ["name"]=> string(6) "ブルドック" ["count"]=> string(1) "1" } [6]=> object(stdClass)#2920 (2) { ["name"]=> string(6) "シーズー" ["count"]=> string(1) "1" } [7]=> object(stdClass)#2919 (2) { ["name"]=> string(6) "ブルドック" ["count"]=> string(1) "1" } } array(0) { }
このまま<li>タグで表示すると下記のようになりカンマで区切られた値がそのまま表示されます。
###問題のリストタグ
<li>柴犬,チワワ,ポメラニアン,パグ</li> <li>柴犬,ボクサー,パグ,プードル,ゴールデンレトリバー</li> <li>ダックスフント,ミニチュアダックスフント</li> <li>チワワ</li> <li>チワワ,ポメラニアン,柴犬</li> <li>ダックスフント</li> <li>ブルドック</li> <li>シーズー</li> <liブルドック</li>
###希望しているリストタグ
<li>柴犬</li> <li>チワワ</li> <li>ポメラニアン</li> <li>パグ</li> <li>ボクサー</li> <li>パグ</li> <li>プードル</li> <li>ゴールデンレトリバー</li> <li>ダックスフント</li> <li>ミニチュアダックスフント</li> <li>チワワ</li> <li>ブルドック</li> <li>シーズー</li>
重複した値をカウントしつつ、ひとつひとつリスト表示させる。
カスタムフィールドの値が一つなら問題は有りませんが値が複数だと上記のように表示させる事ができず
困っています。
###該当のソースコード
function.php(get_meta_values)
function get_meta_values( $key = '', $type = 'post', $status = '' ) { global $wpdb; if( empty( $key ) ) return; $r = $wpdb->get_results( $wpdb->prepare( " SELECT pm.meta_value AS name, count(*) AS count FROM {$wpdb->postmeta} pm LEFT JOIN {$wpdb->posts} p ON p.ID = pm.post_id WHERE pm.meta_key = '%s' AND pm.meta_value != '' AND p.post_type = '%s' GROUP BY pm.meta_value ORDER BY pm.meta_value ", $key, $type)); return $r; }
###補足情報(言語/FW/ツール等のバージョンなど)
WordPress 4.6.1 / Advanced Custom Fields 4.4.8 / PHP5.3.8 / MySQL5.5.16
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/09/19 19:40
2016/09/19 19:47