在開發網頁時,當資料量變大時,將所有資料一次性載入會影響效能與使用者體驗。因此,Laravel 提供了強大的 分頁 (Pagination) 功能,讓我們能夠輕鬆地分批顯示資料。
本文將介紹:
- Laravel 基本分頁
- 簡單分頁 (
simplePaginate()
) - 游標分頁 (
cursorPaginate()
) - 在 Controller 中使用分頁
- 在 Blade 模板中顯示分頁
- API 回傳分頁 JSON
- 自訂分頁樣式(Bootstrap 5)
- 快取分頁結果提升效能
1. Laravel 基本分頁 (paginate()
)
Laravel 提供的 paginate()
方法會自動處理 SQL LIMIT
查詢,讓你輕鬆取得分頁資料。
使用範例
use App\Models\User; $users = User::paginate(10); // 每頁顯示 10 筆資料
這會產生對應的 SQL:
SELECT * FROM users LIMIT 10 OFFSET 0;
當你瀏覽 ?page=2
時,SQL 會自動變為:
SELECT * FROM users LIMIT 10 OFFSET 10;
2. 簡單分頁 (simplePaginate()
)
如果你的資料量非常大,並且不需要顯示「總頁數」,你可以使用 simplePaginate()
,這樣 Laravel 不會執行 COUNT(*) 查詢,效能更佳。
$users = User::simplePaginate(10);
此方法只提供「上一頁」和「下一頁」的按鈕,沒有頁碼顯示,適合大數據網頁。
3. 游標分頁 (cursorPaginate()
)
cursorPaginate()
是 Laravel 8 之後的新功能,適用於資料量龐大時,它不使用 OFFSET
,而是根據「游標」來獲取資料。
使用範例
$users = User::orderBy('id')->cursorPaginate(10);
游標分頁比 paginate()
和 simplePaginate()
更有效率,適合需要不斷載入新資料的結構,如無限滾動(Infinite Scroll)。
4. 在 Controller 中使用分頁
我們可以將分頁邏輯放入 Controller,然後傳遞到 View。
namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Models\User; class UserController extends Controller { public function index() { $users = User::paginate(10); return view('users.index', compact('users')); } }
路由設定
在 routes/web.php
中定義路由:
use App\Http\Controllers\UserController; Route::get('/users', [UserController::class, 'index'])->name('users.index');
5. 在 Blade 模板中顯示分頁
在 resources/views/users/index.blade.php
中顯示分頁結果:
Blade 分頁
<table class="table">
<thead>
<tr>
<th>ID</th>
<th>名稱</th>
<th>Email</th>
</tr>
</thead>
<tbody>
@foreach ($users as $user)
<tr>
<td>{{ $user->id }}</td>
<td>{{ $user->name }}</td>
<td>{{ $user->email }}</td>
</tr>
@endforeach
</tbody>
</table>
<!-- 分頁按鈕 -->
<div class="d-flex justify-content-center">
{{ $users->links() }}
</div>
這樣就可以顯示分頁按鈕,並且 Laravel 會自動偵測 ?page=
參數。
6. API 回傳分頁 JSON
如果你的網頁是 API,可以直接回傳 JSON 格式:
return User::paginate(10);
這會產生 JSON 結果:
{ "current_page": 1, "data": [...], "first_page_url": "...", "last_page_url": "...", "next_page_url": "...", "prev_page_url": "...", "per_page": 10, "total": 100, "last_page": 10 }
7. 自訂分頁樣式(Bootstrap 5)
Laravel 預設使用 Tailwind CSS,但如果你想使用 Bootstrap 5,可以在 AppServiceProvider.php
中設定:
use Illuminate\Pagination\Paginator; public function boot() { Paginator::useBootstrapFive(); }
這樣 {{ $users->links() }}
產生的 HTML 會自動適配 Bootstrap 5 樣式!
8. 快取分頁結果提升效能
如果你的資料變動不頻繁,可以使用 快取 (Cache) 來減少資料庫查詢:
use Illuminate\Support\Facades\Cache; public static function getCachedPaginate() { $page = request()->input('page', 1); return Cache::remember("users_paginate_{$page}", 3600, function () { return self::orderBy('updated_at', 'desc')->paginate(10); }); }
這樣,每個頁數的查詢結果會快取 1 小時 (3600 秒),大幅減少資料庫負擔。
以上就是 Laravel 在快速製作分頁按鈕上的教學。