首页 文章

laravel 4 paginate系列

提问于
浏览
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()

我搜索了这个和许多其他网站,但不知道如何分页集合 .

谢谢你的帮助

3 回答

  • 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);
    
  • 3

    我创建了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;
    }
    
  • 4

    Laravel分页器不会为您进行任何拼接 . 通常,分页器应与Eloquent / Fluent携手使用 . 在你的第二个例子中,你应该这样做 .

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

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

    如果要手动使用paginator,则需要传入拼接数组(当前页面的正确项目) . 这通常涉及确定当前页面,总结果和总页数 . 这就是为什么,最好将它与Eloquent或Fluent一起使用 .

相关问题