web-dev-qa-db-ja.com

WooCommerceの商品検索タイトルのみ

私は以前にこれを尋ね、 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の投稿タイプそのものと関係があると想像します。彼らは多くのカスタムフックなどを入れるのが好きです。

1
kristina childs

これは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にフィルタを追加して修正するようなものにすべきです。あるいはフィルターを外してください。

私はより良い解決策をもっとよく探します、そして私はそれをここに投稿すると約束します。しかし悪い解決策はその仕事をかなりうまくやる。

2
vinigarcia87

これまでのところあなたのプラグインはよさそうです。最後のSQL文字列をダンプして、それを質問に追加してもらえますか。また、WCプラグインは投稿タイプとして投稿テーブルにすべてを保存しますか?もしそうなら:あなたはこの投稿の種類だけで検索する制限を追加しましたか?おそらく、$posts_clauses句の$clauses['where']- filterまたはposts_where- filterの中でそれを行う必要があります。 post_type = postの部分をWCのカスタム投稿タイプに単純に文字列で置き換えます。

0
kaiser