wtyczki – wyszukiwanie produktów woocommerce oparte tylko na tytule
WordPress Development Stack Exchange to strona z pytaniami i odpowiedziami dla programistów i administratorów WordPress. Rejestracja zajmuje tylko minutę.
Zarejestruj się, aby dołączyć do tej społeczności
Każdy może zadać pytanie
Każdy może odpowiedzieć
Najlepsze odpowiedzi są głosowane i wznoszą się na szczyt
Spytał
Oglądane5k razy
cześć, potrzebuję twojej pomocy dotyczącej wyszukiwania opartego na tytule produktu woo-commerce, mamy listę produktów, które moje słowo kluczowe wyszukiwania jest dostępne w tytule produktu, aby wyświetlić listę produktów. jeśli tytuł produktu nie ma mojego słowa kluczowego wyszukiwania, ale jest dostępne w sekcji opisu produktu, nie musi to wyświetlać tego produktu.
dodaj poniższy kod do pliku function.php w swoim katalogu motywu.
<?php
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 );
?>
Jeśli ktoś musi wyszukiwać tylko według tytułu, ale aby zachować domyślny „-” (myślnik) z wyłączeniem funkcji słowa, oto nieco zaktualizowana wersja:
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 ) );
// Allow words starting with the '-' sign to be excluded from the search!
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;}
lang-php