ディクトレ韓国語という、オンラインで韓国語のリスニングやディクテーションができるサービスを運営しています。
サイトリニューアルする際、WPのカスタム投稿やカスタムフィールドを使うことにしたのですが、サイト内検索の対象にカスタムフィールドがデフォルトでは入らないらしく、検索に引っかからないようになってしまいました。
いろいろ調べて出来たので、解決策を書いておきたいと思います。
目次
WordPressのカスタムフィールドをサイト内検索の対象にする方法
具体的には、下記のサイトで紹介されているコードを子テーマ内のfunction.phpに追記することで、カスタムフィールドの内容を検索に含むことができるようになりました。
参考WordPress内の検索対象にカスタムフィールドも適用する
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
function cf_search_join( $join ) { global $wpdb; if ( is_search() ) { $join .= ' LEFT JOIN ' . $wpdb->postmeta . ' ON ' . $wpdb->posts . '.ID = ' . $wpdb->postmeta . '.post_id '; } return $join; } add_filter( 'posts_join', 'cf_search_join' ); function cf_search_where( $where ) { global $wpdb; if ( is_search() ) { $where = preg_replace( "/\(\s*" . $wpdb->posts . ".post_title\s+LIKE\s*(\'[^\']+\')\s*\)/", "(" . $wpdb->posts . ".post_title LIKE $1) OR (" . $wpdb->postmeta . ".meta_value LIKE $1)", $where ); // 特定のカスタムフィールドを検索対象から外す(※1) // $where .= " AND (" . $wpdb->postmeta . ".meta_key NOT LIKE 'number')"; // $where .= " AND (" . $wpdb->postmeta . ".meta_key NOT LIKE 'zip')"; // $where .= " AND (" . $wpdb->postmeta . ".meta_key NOT LIKE 'access')"; } return $where; } add_filter( 'posts_where', 'cf_search_where' ); function cf_search_distinct( $where ) { global $wpdb; if ( is_search() ) { return "DISTINCT"; } return $where; } add_filter( 'posts_distinct', 'cf_search_distinct' ); // 検索対象を『タイトルのみ』にする function __search_by_title_only( $search, & $wp_query ) { global $wpdb; if ( empty( $search ) ) return $search; // skip processing - no search term in query $q = $wp_query->query_vars; $n = !empty( $q[ 'exact' ] ) ? '' : '%'; $search = $searchand = ''; foreach ( ( array )$q[ 'search_terms' ] as $term ) { $term = esc_sql( like_escape( $term ) ); $search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}')"; $searchand = ' AND '; } if ( !empty( $search ) ) { $search = " AND ({$search}) "; if ( !is_user_logged_in() ) $search .= " AND ($wpdb->posts.post_password = '') "; } return $search; } //add_filter( 'posts_search', '__search_by_title_only', 500, 2 );// (※2) |
また、function.php内の追記する場所を間違えるとうまくいかないので注意しましょう。
私は、元々書いてあったコードの間に中途半端にぶちこんでしまい動かずしばらく悩みました。
↑ここに記入して無事動きました。
コード非常に参考になりました。
ありがとうございました。
コメント