laravel 4 分页集合
Posted
技术标签:
【中文标题】laravel 4 分页集合【英文标题】:laravel 4 paginate collection 【发布时间】:2013-02-20 10:28:30 【问题描述】:我无法使用 laravel 4 创建适当的分页系统。我有以下模型和函数返回集合:
模范餐厅:
public function fooditem()
return $this->hasMany('Fooditem','rest_id');
public function get_rest_foods($id)
return Restaurant::find($id)->fooditem->toArray();
第二个函数以数组的形式返回某个餐厅的所有食物。我也在 API 调用中使用它。
在我的控制器中我有这个:
$food = $food->get_rest_foods($id);
$paginator = Paginator::make($food, 10, 5);
我将分页器传递给视图,它显示链接正常,但也显示了食物数组中的所有项目。
我尝试过使用
public function get_rest_foods($id)
return Restaurant::find($id)->fooditem->paginate(5);
但我得到一个错误:
FatalErrorException: 错误:调用未定义的方法 Illuminate\Database\Eloquent\Collection::paginate()
我搜索了这个网站和许多其他网站,但不明白如何对集合进行分页。
感谢您的帮助
【问题讨论】:
【参考方案1】:分页器必须获取它通常从带有偏移/限制语句的数据库查询中获取的项目。 所以当你有一个包含所有项目的集合时,你应该自己做偏移/限制。
$food = $food->get_rest_foods($id);
$page = 1;
if( !empty(Input::get['page']) )
$page = Input::get['page'];
$perPage = 15;
$offset = (($page - 1) * $perPage);
$food = Paginator::make($food->slice($offset,$perPage, true)->all(), $food->count(), $perPage);
【讨论】:
在 L4.2 输入::get('page') 非常感谢!允许我创建插入到集合中的自定义分页项。【参考方案2】:我创建了一个 Collection 的子类并实现了我自己的分页方法
public function paginate($perPage)
$pagination = App::make('paginator');
$count = $this->count();
$page = $pagination->getCurrentPage($count);
$items = $this->slice(($page - 1) * $perPage, $perPage)->all();
$pagination = $pagination->make($items, $count, $perPage);
return $pagination;
【讨论】:
这仅在加载完整的应用程序堆栈时才有效。如果您单独使用 l4 组件,请完成预期这可以工作【参考方案3】:Laravel 分页器不会为你做任何拼接。通常,分页器应与 Eloquent/Fluent 一起使用。在您的第二个示例中,您应该这样做。
return Restaurant::find($id)->fooditem()->paginate(5);
如果不调用实际方法,您只会获得结果集合,而不是查询构建器实例。
如果要手动使用分页器,则需要传入拼接数组(当前页面的正确项)。这通常涉及确定当前页、总结果和总页数。这就是为什么在可能的情况下,最好将它与 Eloquent 或 Fluent 一起使用。
【讨论】:
以上是关于laravel 4 分页集合的主要内容,如果未能解决你的问题,请参考以下文章