让WordPress后台用户列表可以搜索名字、姓氏和公开显示名

美丽的小花园有许多榕树,一簇簇树叶伸到路面上,树叶真绿的可爱。榕树正在茂盛的时期,好象把它全部生命力都展示给我们看。那么多的树叶,一簇堆在另一簇上面,不留一点缝隙,我仿佛也成了一片树叶。那翠绿的颜色明亮地照耀着我的眼睛,似乎每片叶子上都颤动着一个新的生命。这美丽的北国树啊。

默认情况下,在WordPress后台的用户列表中,只能通过用户名和邮箱搜索用户。

如果你希望能通过搜索用户的名字、姓氏和公开显示名找到用户,你可以将下面的代码添加到当前主题的 functions.php 文件即可:

/*
 * 让WordPress后台用户列表可以搜索名字、姓氏和公开显示名
 * From https://www.wpdaxue.com/wordpress-user-search.html
 */
//让函数只应用于WordPress后台
if (is_admin()) {
	//通过钩子挂载函数
	add_action('pre_user_query', 'wpdaxue_pre_user_query');
 }

function wpdaxue_pre_user_query($user_search) {
	global $wpdb;
	$vars = $user_search->query_vars;
	if (!is_null($vars['search'])) {
	// 出于某种原因,搜索词被星号包括,删除它们
		$search = preg_replace('/^\*/', '', $vars['search']);
		$search = preg_replace('/\*$/', '', $search);

		//搜索公开显示名
		if(!empty($search)){
			$user_search->query_where = substr(trim($user_search->query_where), 0, -1) . " OR display_name LIKE '%". $search . "%')";
		}
		//搜索名字和姓氏
		$user_search->query_from .= " INNER JOIN {$wpdb->usermeta} m1 ON " .
		"{$wpdb->users}.ID=m1.user_id AND (m1.meta_key='first_name')";
		$user_search->query_from .= " INNER JOIN {$wpdb->usermeta} m2 ON " .
		"{$wpdb->users}.ID=m2.user_id AND (m2.meta_key='last_name')";
		$names_where = $wpdb->prepare("m1.meta_value LIKE '%s' OR m2.meta_value LIKE '%s'", "%{$search}%", "%$search%");
		$user_search->query_where = str_replace('WHERE 1=1 AND (', "WHERE 1=1 AND ({$names_where} OR ", $user_search->query_where);
	}
	return $user_search;
}

/* * 让WordPress后台用户列表可以搜索名字、姓氏和公开显示名 * From https://www.wpdaxue.com/wordpress-user-search.html */ //让函数只应用于WordPress后台 if (is_admin()) { //通过钩子挂载函数 add_action('pre_user_query', 'wpdaxue_pre_user_query'); } function wpdaxue_pre_user_query($user_search) { global $wpdb; $vars = $user_search->query_vars; if (!is_null($vars['search'])) { // 出于某种原因,搜索词被星号包括,删除它们 $search = preg_replace('/^\*/', '', $vars['search']); $search = preg_replace('/\*$/', '', $search); //搜索公开显示名 if(!empty($search)){ $user_search->query_where = substr(trim($user_search->query_where), 0, -1) . " OR display_name LIKE '%". $search . "%')"; } //搜索名字和姓氏 $user_search->query_from .= " INNER JOIN {$wpdb->usermeta} m1 ON " . "{$wpdb->users}.ID=m1.user_id AND (m1.meta_key='first_name')"; $user_search->query_from .= " INNER JOIN {$wpdb->usermeta} m2 ON " . "{$wpdb->users}.ID=m2.user_id AND (m2.meta_key='last_name')"; $names_where = $wpdb->prepare("m1.meta_value LIKE '%s' OR m2.meta_value LIKE '%s'", "%{$search}%", "%$search%"); $user_search->query_where = str_replace('WHERE 1=1 AND (', "WHERE 1=1 AND ({$names_where} OR ", $user_search->query_where); } return $user_search; }

如果以上的代码仍不能满足你的要求,那你可以试试 Better User Search 插件,它可以让你的用户列表页面支持搜索所有字段。

本文让WordPress后台用户列表可以搜索名字、姓氏和公开显示名到此结束。外貌决定有没有可能在一起,性格决定适不适合在一起,物质决定能不能稳定的在一起,信任决定能不能长久的在一起。小编再次感谢大家对我们的支持!