laravel 使用自定义视图分页

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

如果您想要指定自定义的视图来使用分页,您可以使用 links 方法:
<?php echo $users->links('view.name'); ?>
然后就没了,得了,还是自己看代码吧,

追踪代码思路如下:

找到 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 自定义视图分页

显示效果

page.jpg

2 个评论

袁超

袁超

正在写 基于 laravel 4.2 的博客系统,https://github.com/yccphp/laravel-blog 求 start,watch, 同时我发布的 laravel 系列的文章,都可以在此博客系统中体现出来
2015-01-14 16:59
习惯孤独

习惯孤独

用数据库的limit方式查询,再结合自身的分布类是不是更简单些呢,DB类有take +skip,,Eloquent有limit+offset
2015-01-21 23:07

要回复文章请先登录注册