摘要:目前,無(wú)法高效執(zhí)行使用語(yǔ)句的分頁(yè)操作。如果你需要在分頁(yè)結(jié)果集中使用,建議你查詢數(shù)據(jù)庫(kù)并手動(dòng)創(chuàng)建分頁(yè)器。手動(dòng)創(chuàng)建分頁(yè)如果你想手動(dòng)創(chuàng)建分頁(yè)實(shí)例并且最終得到一個(gè)數(shù)組類型的結(jié)果,可以根據(jù)需求來(lái)創(chuàng)建或者實(shí)例來(lái)實(shí)現(xiàn)。
laravel分頁(yè)功能:
有幾種方法可以對(duì)數(shù)據(jù)進(jìn)行分頁(yè)。最簡(jiǎn)單的是在 [查詢語(yǔ)句構(gòu)造器] 或 [Eloquent 查詢] 中使用 paginate 或 simplePaginate 方法。
paginate用法如下:
//控制器中 $users = DB::table("users")->paginate(15); return view("user.index", ["users" => $users]); //視圖中 {{ $users->links() }}
效果如下:
「上一頁(yè)」 「1」「2」「3」 「下一頁(yè)」
simplePaginate用法如下:
//控制器中 $users = User::where("votes", ">", 100)->simplePaginate(15); return view("user.index", compact("users")); //視圖中 {{ $users->links() }}
效果如下:
「上一頁(yè)」 「下一頁(yè)」
注意:
如果你只需要在分頁(yè)視圖中顯示簡(jiǎn)單的「下一頁(yè)」和「上一頁(yè)」的鏈接,即不需要顯示每個(gè)頁(yè)碼的鏈接,更推薦使用 simplePaginate 方法來(lái)執(zhí)行更高效的查詢。
目前,Laravel 無(wú)法高效執(zhí)行使用 groupBy 語(yǔ)句的分頁(yè)操作。如果你需要在分頁(yè)結(jié)果集中使用 groupBy,建議你查詢數(shù)據(jù)庫(kù)并手動(dòng)創(chuàng)建分頁(yè)器。
有時(shí)候可能會(huì)遇到這種情況,$dataA和$dataB是從數(shù)據(jù)庫(kù)取出的兩個(gè)不同的數(shù)據(jù)集合,需要同時(shí)將$dataA和$dataB分配到視圖并進(jìn)行分頁(yè)展示,那這種情況怎么辦呢?
這種情況可以采用laravel數(shù)組分頁(yè)。
其實(shí)在laravel文檔中已經(jīng)有寫如何自己使用分頁(yè)類去分頁(yè)了,但沒(méi)有 詳細(xì)說(shuō)明。
手動(dòng)創(chuàng)建分頁(yè)
如果你想手動(dòng)創(chuàng)建分頁(yè)實(shí)例并且最終得到一個(gè)數(shù)組類型的結(jié)果,可以根據(jù)需求來(lái)創(chuàng)建 IlluminatePaginationPaginator 或者 IlluminatePaginationLengthAwarePaginator 實(shí)例來(lái)實(shí)現(xiàn)。
具體可以看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); }
以下為具體實(shí)現(xiàn)代碼:
//控制器中 public function index(LiveService $liveService, Request $request) { //數(shù)據(jù)A $dataA = User::where("status", 1)->get()->toArray(); //數(shù)據(jù)B $dataB = User::where("status", 2)->get()->toArray(); $data = array_merge($dataA, $dataB); //當(dāng)前頁(yè)數(shù) 默認(rèn)1 $page = $request->page ?: 1; //每頁(yè)的條數(shù) $perPage = 4; //計(jì)算每頁(yè)分頁(yè)的初始位置 $offset = ($page * $perPage) - $perPage; //實(shí)例化LengthAwarePaginator類,并傳入對(duì)應(yīng)的參數(shù) $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() }}
以上基本就完成了數(shù)組分頁(yè),大致流程就是控制器獲取到當(dāng)前頁(yè)數(shù),實(shí)例化LengthAwarePaginator類并傳入必要的參數(shù),根據(jù)每頁(yè)的條數(shù)利用array_slice()方法獲取每頁(yè)要顯示的數(shù)據(jù)。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/28760.html
摘要:的分頁(yè)組件默認(rèn)為的分頁(yè)樣式,但如果我們用的并不是或者說(shuō)分頁(yè)的結(jié)構(gòu)不一樣,這時(shí)我們需要自定義分頁(yè)。進(jìn)一步,可以看到通過(guò)繼承并對(duì)方法進(jìn)行重寫,由此可見(jiàn),我們可以通過(guò)繼承類并對(duì)方法進(jìn)行重寫,就可以自定義分頁(yè)的樣式了。 ????????Laravel 的分頁(yè)組件默認(rèn)為 Bootstrap 的分頁(yè)樣式,但如果我們用的并不是 Bootstrap 或者說(shuō)分頁(yè)的 HTML結(jié)構(gòu)不一樣,這時(shí)我們需要自定義...
摘要:新增了很多的新特性,包括了內(nèi)置多用戶認(rèn)證表單數(shù)組輸入驗(yàn)證隱式路由模型綁定中間件組的定義中間件訪問(wèn)頻率限制等主要功能。相對(duì)于變化有點(diǎn)大,簡(jiǎn)化了的目錄結(jié)構(gòu),并將路由分離出來(lái)。由于已將的路由單獨(dú)分離出來(lái),因此只需在中添加路由規(guī)則。 Laravel 5.2 新增了很多的新特性,包括了內(nèi)置多用戶認(rèn)證、表單數(shù)組輸入驗(yàn)證、隱式路由模型綁定、中間件組的定義、中間件 throttle 訪問(wèn)頻率限制等主要...
摘要:軟刪除當(dāng)模型被軟刪除后,它們并沒(méi)有真的從數(shù)據(jù)庫(kù)刪除,而是在模型上設(shè)置一個(gè)屬性并插入數(shù)據(jù)庫(kù),如果模型有一個(gè)非空值,那么該模型已經(jīng)被軟刪除了。 Laravel 中Eloquent ORM 相關(guān)操作 定義 操作 獲?。ú樵儯?獲取集合,(查詢列表) 返回值是 IlluminateDatabaseEloquentCollection 的一個(gè)實(shí)例 獲取所有的數(shù)據(jù) use AppUser; $us...
摘要:創(chuàng)建重寫方法的類創(chuàng)建文件創(chuàng)建服務(wù)提供者自定義分頁(yè)將服務(wù)提供者添加到討論群歡迎加入實(shí)例源碼我的開(kāi)源博客 需求介紹 laravel默認(rèn)了分頁(yè),實(shí)現(xiàn)非常優(yōu)雅,但有時(shí)候會(huì)遇到修改默認(rèn)的樣式,比如我要將默認(rèn)的修改為 解決辦法切入點(diǎn) Laravel自帶的分頁(yè)鏈接樣式由IlluminatePaginationBootstrapThreePresenter的render方法生成,我們?cè)诖朔椒ㄉ献鑫恼录?..
摘要:最近再拿寫博客系統(tǒng),里面需要分頁(yè),想自定義,于是百度了一圈,都是什么修改之類的,這樣治標(biāo)不治本嘛,于是查看手冊(cè),發(fā)現(xiàn)如下如果您想要指定自定義的視圖來(lái)使用分頁(yè),您可以使用方法然后就沒(méi)了,得了,還是自己看代碼吧,追蹤代碼思路如下找到方法,在第行 最近再拿 laravel 寫博客系統(tǒng),里面需要分頁(yè),想自定義,于是百度了一圈,都是什么修改 css,之類的,這樣治標(biāo)不治本嘛,于是查看 larav...
閱讀 2139·2023-04-26 01:59
閱讀 3427·2021-10-11 11:07
閱讀 3490·2021-09-22 15:43
閱讀 3534·2021-09-02 15:21
閱讀 2788·2021-09-01 10:49
閱讀 1035·2019-08-29 15:15
閱讀 3273·2019-08-29 13:59
閱讀 2964·2019-08-26 13:36