我无法使用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()
我搜索了这个和许多其他网站,但不能理解如何对一个集合进行分页。
感谢您的帮助
答案 0 :(得分:5)
paginator必须通过offset / limit语句获取通常从数据库查询中获取的项。 所以当你有一个包含所有项目的集合时,你应该自己做偏移/限制。
$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);
答案 1 :(得分:4)
我创建了Collection的子类并实现了我自己的paginate方法
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;
}
答案 2 :(得分:3)
Laravel分页器不会为您进行任何拼接。通常,分页器应与Eloquent / Fluent携手使用。在你的第二个例子中,你应该这样做。
return Restaurant::find($id)->fooditem()->paginate(5);
如果不调用实际方法,您只需获取结果集合,而不是查询构建器实例。
如果要手动使用paginator,则需要传入拼接数组(当前页面的正确项目)。这通常涉及确定当前页面,总结果和总页数。这就是为什么,最好将它与Eloquent或Fluent一起使用。