荆轲刺秦王
WordPress的设计不同于其他MVC模式的PHP框架,它的大部分功能是由插件来实现,所以我们在修改后台功能的时候,大部分也都是在 function.php 和 js/main.js 里面修改。
先看数据表,WordPress自带的基础数据库已经有了 User 表,并且有 registered_time 这个字段,虽然不是时间戳格式,但依旧不影响我们对他进行排序。
废话不多说,看代码:
//WordPress order by registered_time
add_filter( 'manage_users_columns', 'my_users_columns' );
function my_users_columns( $columns ){
$columns[ 'registered' ] = 'Registration time';
return $columns;
}
add_action( 'manage_users_custom_column', 'output_my_users_columns', 10, 3 );
function output_my_users_columns( $var, $column_name, $user_id ){
switch( $column_name ) {
case "registered" :
return get_user_by('id', $user_id)->data->user_registered;
break;
}
}
add_filter( "manage_users_sortable_columns", 'wenshuo_users_sortable_columns' );
function wenshuo_users_sortable_columns($sortable_columns){
$sortable_columns['registered'] = 'registered';
return $sortable_columns;
}
add_action( 'pre_user_query', 'wenshuo_users_search_order' );
function wenshuo_users_search_order($obj){
if(!isset($_REQUEST['orderby']) || $_REQUEST['orderby']=='registered' ){
if( !in_array($_REQUEST['order'],array('asc','desc')) ){
$_REQUEST['order'] = 'desc';
}
$obj->query_orderby = "ORDER BY user_registered ".$_REQUEST['order']."";
}
}
实现的效果,是在后台用户列表页面出现了一列注册时间,因为老板喜欢看英文,所以这一列的名称是:Registration time
然后点击 Registration time 右边的小三角可以正序,倒序排列,已经符合了我的业务需求。