Laravel5.1+ 分页Pagination解析以及扩展
5.1和5.2应该是同样的方法,我这里用的是5.2的版本。文档告诉我们 Paginator对应于查询语句构造器和 Eloquent 的 simplePaginate方法,而 LengthAwarePaginator则等同于 paginate方法。那我们还是来看下源码,具体这个 paginate是如何实现 render()的,
- Illuminate/Pagination/LengthAwarePaginator.php
render(); }......}
render()中传入的是一个 Presenter的实例,并调用这个实例化的 render方法来实现分页的显示的。如果没有则调用 BootstrapThreePresenter中 render()的,来看看 BootstrapThreePresenter是干嘛的
- Illuminate/Pagination/BootstrapThreePresenter.php
paginator = $paginator; $this->window = is_null($window) ? UrlWindow::make($paginator) : $window->get(); } /** * Determine if the underlying paginator being presented has pages to show. * * @return bool */ public function hasPages() { return $this->paginator->hasPages(); } /** * Convert the URL window into Bootstrap HTML. * * @return \Illuminate\Support\HtmlString */ public function render() { if ($this->hasPages()) { return new HtmlString(sprintf( '
- %s %s %s
这里可以看到 BootstrapThreePresenter实现了 PresenterContract的接口, render()才是分页显示的真正实现,构造方法中的第一个参数 PaginatorContract其实就是一个 Paginator我们继续看下 PresenterContract也就是 Presenter接口中定义了什么方法需要实现
- illuminate/contracts/Pagination/Presenter.php
其中定义了 render和 hasPages方法需要实现
好了,那我们现在已经很清晰了,我们要自定义分页的显示,那么就要写一个我们自己的 Presenter来实现接口中的 render()和 hasPages()就可以了。
首先就来简单的实现一个paginate(),显示出来"上一页"和"下一页",中间是分页数字的例子。
新建文件如下(个人习惯) app/Foundations/Pagination/CustomerPresenter.php
paginator = $paginator; $this->window = is_null($window) ? UrlWindow::make($paginator) : $window->get(); } /** * Determine if the underlying paginator being presented has pages to show. * * @return bool */ public function hasPages() { return $this->paginator->hasPages(); } /** * Convert the URL window into Bootstrap HTML. * * @return \Illuminate\Support\HtmlString */ public function render() { if ($this->hasPages()) { return new HtmlString(sprintf( '
- %s %s %s
就这么简单,主要就是 render()方法,如果项目中需要修改分页样式,或者添加分页跳转之类的需求只要重写其中的各项显示的方法中的html元素就可以了,很灵活,在blade模板中也需要修该,比如我们的 Paginator叫 $users,默认的分页显示是这样的:
{!! $users->render() !!}
修改成我们自定义后的分页显示:
{!! with(new \App\Foundations\Pagination\CustomerPresenter($categories))->render() !!}
好了,这样在页面应该就可以看到分页链接中含有 "上一页"和"下一页"加数字的样式了。
那么如果扩展simplePaginate?其实很简单,只要继承刚才的 CustomerPresenter,实现 hasPages和 render,至于为什么可以按照我上面查看源码的方式看一下就知道了,比如我们改成"上一篇"和"下一篇"
新建App\Foundations\Pagination\CustomerSimplePresenter.php
paginator = $paginator; } /** * Determine if the underlying paginator being presented has pages to show. * * @return bool */ public function hasPages() { return $this->paginator->hasPages() && count($this->paginator->items()) > 0; } /** * Convert the URL window into Bootstrap HTML. * * @return \Illuminate\Support\HtmlString */ public function render() { if ($this->hasPages()) { return new HtmlString(sprintf( '
- %s %s
分页显示:
{!! with(new \App\Foundations\Pagination\CustomerSimplePresenter($categories))->render() !!}
方法就是这个方法,具体修改按照自己需求重写其中对应的显示html元素的方法就可以了。
转载请注明:转载自 Ryan是菜鸟 | LNMP技术栈笔记
如果觉得本篇文章对您十分有益,何不打赏一下
上一篇: Access如何打开一个表