私は以前にこれを尋ね、 Relevanssi プラグインを使用して解決しましたが、このプラグインは現在壊れているので使用できなくなりました。どのようにして非常におかしい単純なことがwoocommerceによってとても不可能にされたのですか? AAARG!
私は この解決方法 を使ってみましたが、私にはうまくいきませんでした。また、私はwoocommerceのproduct_search
関数を探してそれにフィルタを追加しようとしましたが、それについても何も得られませんでした。
これは私が試した最後のもので、タイトルだけでなく、すべてのコンテンツから検索結果が返されたものです。
MarkUp
<form role="search" method="get" id="searchform" action="<?php echo home_url( '/' ); ?>">
<input type="hidden" name="post_type" value="product" />
<input type="text" value="" name="s" />
<input type="submit" value="Search" />
</form>
検索SQLフィルタコールバック
// Search product titles only.
function __search_by_title_only( $search, &$wp_query ) {
global $wpdb;
if($_GET['post_type'] = 'product' )
return $search;
$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 );
誰でも?私はそれがwoocommerceの投稿タイプそのものと関係があると想像します。彼らは多くのカスタムフックなどを入れるのが好きです。
これは9か月の質問ですが、私は同じ問題を抱えていて解決策を見つけたので、私はそれを投稿するためにここに来ました。
ファイルwp-content/plugins/woocommerce/classes/class-wc-query.php
の関数pre_get_posts( $q )
では、WooCommerceは114行目で次のように定義しています。
add_filter( 'posts_where', array( $this, 'search_post_excerpt' ) );
これがWooCommerceがあなたの質問をめちゃくちゃにする時のポイントです!
関数search_post_excerpt
は132行目の右下で定義されています。そして、彼が検索クエリに抜粋を追加しているのがわかります。
2つの解決策があります。
悪いのは、114行目をコメントすることです!
//add_filter( 'posts_where', array( $this, 'search_post_excerpt' ) );
良いことに、私は自分では実装しませんでしたが、WooCommerceの後に実行されるposts_where
にフィルタを追加して修正するようなものにすべきです。あるいはフィルターを外してください。
私はより良い解決策をもっとよく探します、そして私はそれをここに投稿すると約束します。しかし悪い解決策はその仕事をかなりうまくやる。
これまでのところあなたのプラグインはよさそうです。最後のSQL文字列をダンプして、それを質問に追加してもらえますか。また、WCプラグインは投稿タイプとして投稿テーブルにすべてを保存しますか?もしそうなら:あなたはこの投稿の種類だけで検索する制限を追加しましたか?おそらく、$posts_clauses
句の$clauses['where']
- filterまたはposts_where
- filterの中でそれを行う必要があります。 post_type = post
の部分をWCのカスタム投稿タイプに単純に文字列で置き換えます。