как ограничить поиск заголовками сообщений?

27

Есть ли способ ограничить поиск постами? Я знаю, что могу изменить основной файл query.php, но должен быть способ сделать это с помощью хуков, верно?

Заранее спасибо!

Хавьер Вильянуэва
источник

Ответы:

32

Вот фильтр, который сделает свое дело. Оставьте это в своей теме functions.phpили плагине.

/**
 * Search SQL filter for matching against post title only.
 *
 * @link    http://wordpress.stackexchange.com/a/11826/1685
 *
 * @param   string      $search
 * @param   WP_Query    $wp_query
 */
function wpse_11826_search_by_title( $search, $wp_query ) {
    if ( ! empty( $search ) && ! empty( $wp_query->query_vars['search_terms'] ) ) {
        global $wpdb;

        $q = $wp_query->query_vars;
        $n = ! empty( $q['exact'] ) ? '' : '%';

        $search = array();

        foreach ( ( array ) $q['search_terms'] as $term )
            $search[] = $wpdb->prepare( "$wpdb->posts.post_title LIKE %s", $n . $wpdb->esc_like( $term ) . $n );

        if ( ! is_user_logged_in() )
            $search[] = "$wpdb->posts.post_password = ''";

        $search = ' AND ' . implode( ' AND ', $search );
    }

    return $search;
}

add_filter( 'posts_search', 'wpse_11826_search_by_title', 10, 2 );

Большая часть кода просто скопирована из WP_Queryкласса, за исключением случаев post_content LIKEудаления.

ОБНОВЛЕНИЕ: Удалено устарело like_escape()с 4.0

TheDeadMedic
источник
отлично работает отлично, я знал, что для этого был фильтр, не мог найти его нигде в кодексе, большое спасибо!
Хавьер Вильянуэва
@TheDeadMedic Я только что попробовал это в своем блоге, и этот конкретный запрос теперь не дает результата вообще, с этим кодом или без него. Любые идеи?
Ashfame
Теперь он работает как обычно без кода, но код не работает для меня. Он показал те же результаты: /
Ashfame
@ Ashfame Я пересмотрел свой ответ.
TheDeadMedic
1
Сообщение PHP: Неустранимая ошибка PHP: вызов неопределенного метода wpdb :: esc_like () --- Если у вас более старый WordPress, это новая функция с WP 4.0
PJ Brunet,