Поиск продуктов WooCommerce только по заголовку

Вопрос или проблема

Привет, мне нужна твоя помощь по поиску товаров в WooCommerce по названию. У нас есть список товаров, и мне нужно, чтобы при поиске по ключевому слову отображался список товаров, в названии которых есть это ключевое слово. Если ключевое слово отсутствует в названии товара, но присутствует в разделе описания товара, этот товар отображаться не должен.

Добавьте следующий код в файл functions.php в директории вашей темы.

<?php
    function __search_by_title_only( $search, &$wp_query )
    {
        global $wpdb;
        if ( empty( $search ) )
            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 );
?>

Если кто-то хочет выполнять поиск только по заголовку, но при этом сохранить стандартную функциональность исключения слов со знаком “-” (дефис), вот немного обновленная версия:

function __search_by_title_only( $search, &$wp_query ) {
global $wpdb;
if ( empty( $search ) )
    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 ) );
    // Позволяет исключать слова, начинающиеся с символа '-'
    if (str_starts_with($term, '-')) {
        $term = substr($term, 1);
        $search .= "{$searchand}($wpdb->posts.post_title NOT LIKE '{$n}{$term}{$n}')";
    } else {
        $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;}

Ответ или решение

Для реализации поиска продуктов в WooCommerce только по заголовкам, вам необходимо добавить следующий код в файл functions.php вашей темы. Этот код изменит стандартный механизм поиска так, чтобы он учитывал только заголовки продуктов, игнорируя описания.

Ниже приведен пример кода, который вы можете использовать:

<?php
function __search_by_title_only( $search, &$wp_query ) {
    global $wpdb;
    if ( empty( $search ) )
        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 ) );

        // Позволяем словам, начинающимся с '-', исключаться из поиска
        if (str_starts_with($term, '-')) {
            $term = substr($term, 1);
            $search .= "{$searchand}($wpdb->posts.post_title NOT LIKE '{$n}{$term}{$n}')";
        } else {
            $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 );
?>

Что делает этот код:

  1. Функция __search_by_title_only: Эта функция перехватывает запросы поиска, выполняемых в WordPress, и изменяет их так, чтобы они искали только по полю заголовка (post_title).

  2. Обработка термина поиска: Код проверяет, есть ли в запросе термины поиска. Если термина нет, обработка прекращается.

  3. Исключение слов с -: Если термин поиска начинается с символа -, этот термин будет исключен из результатов поиска.

  4. Добавление условий поиска: Каждое условие поиска добавляется к переменной $search.

  5. Фильтр posts_search: Фильтр WordPress posts_search применяется к запросу, что позволяет изменять поведение механизма поиска.

Примечание:

Убедитесь, что вы делаете резервную копию вашего файла functions.php перед внесением изменений. Это поможет избежать потери данных в случае, если что-то пойдет не так. После внесения изменений протестируйте поиск на вашем сайте, чтобы убедиться, что он работает согласно вашим требованиям.

Оцените материал
Добавить комментарий

Капча загружается...