在 Laravel 中,要实现手动分页,你需要创建一个自定义分页器。以下是实现手动分页的步骤:
- 首先,从数据库中获取所有记录。例如,如果你想从
users
表中获取所有记录,可以使用 Eloquent ORM:
$allUsers = User::all();
- 确定每页显示的记录数。例如,如果你想每页显示 10 条记录,可以将其存储在一个变量中:
$perPage = 10;
- 计算当前页码。你可以从请求中获取当前页码,或者默认为 1:
$currentPage = request()->input('page', 1);
- 根据当前页码和每页显示的记录数,对记录进行切片:
$start = ($currentPage - 1) * $perPage; $users = array_slice($allUsers->toArray(), $start, $perPage);
- 创建一个新的分页器实例。将切片后的记录、总记录数、每页显示的记录数和当前页码传递给分页器:
use Illuminate\Pagination\LengthAwarePaginator; $paginatedUsers = new LengthAwarePaginator($users, count($allUsers), $perPage, $currentPage, [ 'path' => LengthAwarePaginator::resolveCurrentPath(), ]);
- 最后,将分页器实例传递给视图:
return view('your-view', ['users' => $paginatedUsers]);
- 在视图中,使用
links()
方法渲染分页链接:
{{ $users->links() }}
这样,你就可以在 Laravel 中实现手动分页了。请注意,这种方法可能不适用于大型数据集,因为它会一次性加载所有记录。对于大型数据集,建议使用数据库查询构建器或 Eloquent ORM 进行分页。