如何在 Laravel 中创建分页?
我的模型
发布
function comments() {
return $this->hasMany('Comment')
->orderBy('created_at', 'desc');
}
评论
function posts(){
return $this->belongsTo('Post');
}
用户
function posts(){
return $this->hasMany('Post');
}
function comments(){
return $this->hasMany('Comment');
}
用户 Controller
$user = User::find(1); //this will give me all the user's post and comment details
//i know I can do $user = User::paginate(30) to get 30 user per page
我想要实现的目标
我想创建每页 10 条评论的分页。
提前感谢您的帮助。
最佳答案
您有两种选择:您可以在关系查询上调用 paginate()
,或者您可以手动创建分页器。
在关系查询上调用 paginate()
(使用关系函数):
$user = User::find(1);
$comments = $user->comments()->paginate(10);
手动创建分页器(使用关系属性):
$user = User::find(1);
$paginator = Paginator::make($user->comments, $user->comments->count(), 10);
可以找到分页文档 here 。
关于php - Laravel 分页,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30534867/