Вопрос или проблема
Привет, мне нужна твоя помощь по поиску товаров в 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 );
?>
Что делает этот код:
-
Функция
__search_by_title_only
: Эта функция перехватывает запросы поиска, выполняемых в WordPress, и изменяет их так, чтобы они искали только по полю заголовка (post_title
). -
Обработка термина поиска: Код проверяет, есть ли в запросе термины поиска. Если термина нет, обработка прекращается.
-
Исключение слов с
-
: Если термин поиска начинается с символа-
, этот термин будет исключен из результатов поиска. -
Добавление условий поиска: Каждое условие поиска добавляется к переменной
$search
. -
Фильтр
posts_search
: Фильтр WordPressposts_search
применяется к запросу, что позволяет изменять поведение механизма поиска.
Примечание:
Убедитесь, что вы делаете резервную копию вашего файла functions.php
перед внесением изменений. Это поможет избежать потери данных в случае, если что-то пойдет не так. После внесения изменений протестируйте поиск на вашем сайте, чтобы убедиться, что он работает согласно вашим требованиям.