定制WordPress默认的用户搜索 - 文章教程

定制WordPress默认的用户搜索

发布于 2017-05-23 字数 2122 浏览 2777 评论 0

今天想给本站添加一个用户搜索的功能,于是想到了WordPress自带的 get_users 函数,在参数里面配置 search 字段,就可以搜索用户了,但是使用的时候非常奇怪,只有输入用户的全称才能找到用户,而输入一些模糊的字段,基本都找不到。

定制WordPress默认的用户搜索

WordPress用户搜索默认是基于用户的 user_loginuser_nicename 进行搜索的,但是这样的搜索内容并没有很大的用处,我在主题里面显示用户的中文名是采用的 display_name,还有WordPress默认的描述字段,我都希望能够通过关键字搜索到这些字段。

通过查找相关的API文档,我们可以使用 pre_user_queryaction,定制 get_users 函数的参数,从而实现我们想要的内容:

add_action( 'pre_user_query', 'wt_user_query', 9 );
function wt_user_query($query){
    if(!empty($query->query_vars['search'])){
        global $wpdb;
        $keyword = $query->query_vars['search'];
        $keyword = str_replace('*','',$keyword);
        $query->query_where = $wpdb->prepare(" WHERE 1=1 AND (user_login LIKE %s OR user_email LIKE %s OR user_nicename LIKE %s OR display_name LIKE %s OR UM.meta_value LIKE  %s) AND UM.meta_key='nickname'","%".$keyword."%","%".$keyword."%","%".$keyword."%","%".$keyword."%","%".$keyword."%");
        $query->query_fields .= " ,$wpdb->users.display_name, UM.meta_value as nickname";
        $query->query_from .= " left join $wpdb->usermeta UM on ($wpdb->users.ID=UM.user_id) ";
    }
}

将上面的代码添加到我们的主题的 functions.php 文件即可,这个方法针对于小网站小数据,如果你的网站数据量很大,那么这个方法并不适合你,原因就是用到了MySQL的LIKE语句。

下面是相关搜索代码:

$args = array(
    'search' => $_GET['s'], //匹配搜索词
    'number' => 5, //显示用户数量
);
$blogusers = get_users($args);

如果你对这篇文章有疑问,欢迎到本站 社区 发帖提问或使用手Q扫描下方二维码加群参与讨论,获取更多帮助。

扫码加入群聊

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

目前还没有任何评论,快来抢沙发吧!

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

2583 文章
29 评论
84935 人气
更多

推荐作者

清欢

文章 1 评论 0

贱贱哒

文章 3 评论 0

悸初

文章 2 评论 0

西瓜杏

文章 0 评论 0

各自安好

文章 0 评论 0