有没有一种方法可以将搜索限制为发布标题?我知道我可以修改query.php核心文件,但是必须有一种使用钩子正确的方法吗?

预先感谢!

#1 楼

这是一个可以解决问题的过滤器。将其放到主题的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。 >
更新:从4.0开始删除了弃用的like_escape()

评论


非常好的作品,我知道有一个过滤器,无法在法典中的任何地方找到它,非常感谢!

–哈维尔·维拉纽瓦(Javier Villanueva)
2011年3月12日下午16:19

@TheDeadMedic我刚刚在我的博客上尝试过,无论是否包含此代码,该特定查询现在都不会返回任何结果。有任何想法吗?

–嘘声
2011年8月3日23:37

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

–嘘声
11年8月4日在7:32

谢谢,它很好用,如果您删除{$ term}附近的{$ n},它会进行精确搜索。但是有一个问题,它不能用“苹果汁”之类的空白词来代替。但是它会烤苹果。

–user11192
2011-12-16 12:12

PHP消息:PHP致命错误:调用未定义的方法wpdb :: esc_like()---如果您使用的是较旧的WordPress,则这是自WP 4.0起的新功能

– PJ Brunet
2015年11月9日23:14