3

我无法使用 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()

我搜索了这个网站和许多其他网站,但无法理解如何对集合进行分页。

谢谢你的帮助

4

3 回答 3

5

分页器必须获取通常从带有偏移/限制语句的数据库查询中获取的项目。因此,当您拥有包含所有项目的集合时,您应该自己进行偏移/限制。

    $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);
于 2014-11-13T20:23:39.247 回答
4

我创建了 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;
}
于 2014-03-09T06:30:50.623 回答
3

Laravel 分页器不会为你做任何拼接。通常,分页器应与 Eloquent/Fluent 一起使用。在您的第二个示例中,您应该这样做。

return Restaurant::find($id)->fooditem()->paginate(5);

如果不调用实际方法,您将只获得结果集合,而不是查询构建器实例。

如果要手动使用分页器,则需要传入拼接数组(当前页面的正确项)。这通常涉及确定当前页、总结果和总页数。这就是为什么在可能的情况下,最好将它与 Eloquent 或 Fluent 一起使用。

于 2013-04-14T05:56:06.820 回答