如何限制搜索以发布标题?


Answers:


31

这是一个可以解决问题的过滤器。将其放入主题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我刚刚在我的博客上尝试过,无论是否包含此代码,该特定查询现在都不会返回任何结果。有任何想法吗?
Ashfame'8

现在,它没有代码也照常工作,但是代码对我不起作用。它显示了相同的结果:/
Ashfame

@Ashfame我已经修改了答案。
TheDeadMedic

1
PHP消息:PHP致命错误:调用未定义的方法wpdb :: esc_like()---如果您使用的是较旧的WordPress,这是WP 4.0起的新功能
PJ Brunet
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.