预先感谢!
#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