laravel 使用自定义视图分页

来源:互联网 发布:阿里的数据平台 编辑:程序博客网 时间:2024/05/17 07:05

最近再拿 laravel 写博客系统,里面需要分页,想自定义,于是百度了一圈,都是什么修改 css,之类的,这样治标不治本嘛,于是查看 laravel 手册,发现如下

如果您想要指定自定义的视图来使用分页,您可以使用 links 方法:

然后就没了,得了,还是自己看代码吧,

追踪代码思路如下:

找到 links 方法,在 /vendor/laravel/framework/src/Illuminate/Pagination/Paginator.php 第202 行

public function links($view = null){    return $this->factory->getPaginationView($this, $view);}

于是乎追踪到 getPaginationView 方法,

public function getPaginationView(Paginator $paginator, $view = null){    $data = array('environment' => $this, 'paginator' => $paginator);    return $this->view->make($this->getViewName($view), $data);}

现在看懂了,他传递到 view 里面两个参数

于是继续追踪,下面的追踪大家就自己去看了,我说下如何自定义分页视图

view 层:


{{$cate->links('backend._layouts._page')}}

加载我们的 _page 视图

我们看 _page视图的代码

<?php$presenter = new Illuminate\Pagination\BootstrapPresenter($paginator);?>共 {{$paginator->getCurrentPage()}}  条记录<div class="am-fr"><ul class="am-pagination">    <?php echo $presenter->render(); ?></ul></div>

首先我们new BootstrapPresenter 这个类,因为我们需要调用他的 render 方法

render 方法是展示: 1 , 2 ,3 ,4 这样的分页链接

{{$paginator->getTotal()}} 是统计本页多少条数据,更多方法请参考手册
$presenter->render(); 默认是 <li></li> 如果想修改, 在vendor/laravel/framework/src/Illuminate/Pagination/BootstrapPresenter.php直接去修改里面的 html标签就行,非常简单,就实现了 laravel 自定义视图分页

显示效果
图片描述

0 0
原创粉丝点击