Laravel 框架提供了两种分页方式:手动分页和自动分页。它们之间的主要区别在于如何处理数据和生成分页链接。
- 手动分页(Manual Pagination): 手动分页是一种更灵活的分页方式,允许你完全控制分页过程。在这种情况下,你需要手动查询数据库并创建分页实例。这种方法适用于复杂的查询或需要自定义分页逻辑的场景。
手动分页的工作原理:
- 使用
Illuminate\Pagination\LengthAwarePaginator
或Illuminate\Pagination\Paginator
类创建一个分页实例。 - 手动查询数据库以获取当前页的数据。
- 将查询结果和分页信息传递给视图。
示例代码:
use Illuminate\Pagination\LengthAwarePaginator; // 获取当前页数 $page = request()->input('page', 1); // 每页显示的数据量 $perPage = 10; // 查询数据库以获取当前页的数据 $offset = ($page - 1) * $perPage; $items = DB::table('your_table')->skip($offset)->take($perPage)->get(); // 获取总记录数 $total = DB::table('your_table')->count(); // 创建分页实例 $paginator = new LengthAwarePaginator($items, $total, $perPage, $page, [ 'path' => LengthAwarePaginator::resolveCurrentPath(), ]); // 将分页实例传递给视图 return view('your_view', ['items' => $paginator]);
- 自动分页(Eloquent ORM Pagination):
自动分页是 Laravel 提供的一种简化分页方法,适用于简单的查询和分页需求。在这种情况下,你可以直接在 Eloquent 查询上调用
paginate
方法来获取分页数据。
自动分页的工作原理:
- 在 Eloquent 查询上调用
paginate
方法。 - Laravel 会自动处理分页逻辑,包括查询数据库、计算总记录数和生成分页链接。
- 将查询结果和分页信息传递给视图。
示例代码:
// 在控制器中获取分页数据 $items = YourModel::paginate(10); // 将分页数据传递给视图 return view('your_view', ['items' => $items]);
总结:
- 手动分页提供了更高的灵活性,适用于复杂的查询和自定义分页逻辑。
- 自动分页适用于简单的查询和分页需求,易于实现但可能不如手动分页灵活。