WordPress后台用户列表按注册时间排序

荆轲刺秦王

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 右边的小三角可以正序,倒序排列,已经符合了我的业务需求。

你可能感兴趣的:(WordPress)