这篇文章主要介绍如何使用数组创建分页数据,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
说明
使用版本:5.1.35 LTS
遇到的一个场景是,数据是从 RPC 远程调用接口获取的数组,需要在前端页面显示分页。
解决方法
可以使用 think\Paginate 类的 make 方法创建分页数据。make 方法原型:
/** * @access public * @param $items 需要分页的数据 * @param $listRows 每页数据条数 * @param null $currentPage 当前页数 * @param null $total 总页数 * @param bool $simple 是否使用简单模式(只有上一页和下一页) * @param array $options 其他参数选项,如查询参数,url路径等 * @return Paginator 返回一个分页对象 */ public static function make($items, $listRows, $currentPage = null, $total = null, $simple = false, $options = []) { return new static($items, $listRows, $currentPage, $total, $simple, $options); }
需要传入的参数说明见代码注释。
由于 think\Paginate 类的是一个抽象类,需要另一个类继承它才能使用它的公有方法。框架中有 think\paginator\driver\Bootstrap 类继承了它,所以可以使用该类去调用 make 方法。
所以,可以写一个从数组创建分页数据的方法,大概是这样的:
private function getPaginateData($data, $page, $query){ return Bootstrap::make($data, $perPage, $page, $total, false, ['path' => url('module/controller/action'), 'query' => $query]); }
使用该方法生成分页对象后,比如:$data = $this->getPaginateData(...),在控制器中输出到模板,然后就可以在模板页面中添加:
{$data|raw}
模板引擎会自动渲染分页样式。
以上是“如何使用数组创建分页数据”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。