本文介紹了laravel手動創建數組分頁的實現代碼,分享給大家,具體如下:
laravel分頁功能:
有幾種方法可以對數據進行分頁。最簡單的是在 [查詢語句構造器] 或 [Eloquent 查詢] 中使用 paginate 或 simplePaginate 方法。
paginate用法如下:
//控制器中 $users = DB::table('users')->paginate(15); return view('user.index', ['users' => $users]); //視圖中 {{ $users->links() }}
效果如下:
「上一頁」 「1」「2」「3」 「下一頁」
simplePaginate用法如下:
//控制器中 $users = User::where('votes', '>', 100)->simplePaginate(15); return view('user.index', compact('users')); //視圖中 {{ $users->links() }}
效果如下:
「上一頁」 「下一頁」
注意:
- 如果你只需要在分頁視圖中顯示簡單的「下一頁」和「上一頁」的鏈接,即不需要顯示每個頁碼的鏈接,更推薦使用 simplePaginate 方法來執行更高效的查詢。
- 目前,Laravel 無法高效執行使用 groupBy 語句的分頁操作。如果你需要在分頁結果集中使用 groupBy,建議你查詢數據庫并手動創建分頁器。
有時候可能會遇到這種情況,$dataA和$dataB是從數據庫取出的兩個不同的數據集合,需要同時將$dataA和$dataB分配到視圖并進行分頁展示,那這種情況怎么辦呢?
這種情況可以采用laravel數組分頁。
其實在laravel文檔中已經有寫如何自己使用分頁類去分頁了,但沒有 詳細說明。
手動創建分頁
如果你想手動創建分頁實例并且最終得到一個數組類型的結果,可以根據需求來創建 IlluminatePaginationPaginator 或者 IlluminatePaginationLengthAwarePaginator 實例來實現。
具體可以看IlluminatePaginationLengthAwarePaginator中的這段代碼:
public function __construct($items, $total, $perPage, $currentPage = null, array $options = []) { foreach ($options as $key => $value) { $this->{$key} = $value; } $this->total = $total; $this->perPage = $perPage; $this->lastPage = max((int) ceil($total / $perPage), 1); $this->path = $this->path !== '/' ? rtrim($this->path, '/') : $this->path; $this->currentPage = $this->setCurrentPage($currentPage, $this->pageName); $this->items = $items instanceof Collection ? $items : Collection::make($items); }
以下為具體實現代碼:
//控制器中 public function index(LiveService $liveService, Request $request) { //數據A $dataA = User::where('status', 1)->get()->toArray(); //數據B $dataB = User::where('status', 2)->get()->toArray(); $data = array_merge($dataA, $dataB); //當前頁數 默認1 $page = $request->page ?: 1; //每頁的條數 $perPage = 4; //計算每頁分頁的初始位置 $offset = ($page * $perPage) - $perPage; //實例化LengthAwarePaginator類,并傳入對應的參數 $data = new LengthAwarePaginator(array_slice($data, $offset, $perPage, true), count($data), $perPage, $page, ['path' => $request->url(), 'query' => $request->query()]); return view('admin.users.index', compact('data')); } //視圖中 {{ $data->links() }}
以上基本就完成了數組分頁,大致流程就是控制器獲取到當前頁數,實例化LengthAwarePaginator
類并傳入必要的參數,根據每頁的條數利用array_slice()方法獲取每頁要顯示的數據。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。