怎么在laravel中手動(dòng)創(chuàng)建一個(gè)數(shù)組分頁(yè)?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
我們擁有10余年網(wǎng)頁(yè)設(shè)計(jì)和網(wǎng)站建設(shè)經(jīng)驗(yàn),從網(wǎng)站策劃到網(wǎng)站制作,我們的網(wǎng)頁(yè)設(shè)計(jì)師為您提供的解決方案。為企業(yè)提供成都網(wǎng)站制作、網(wǎng)站建設(shè)、微信開發(fā)、小程序開發(fā)、手機(jī)網(wǎng)站開發(fā)、H5技術(shù)、等業(yè)務(wù)。無(wú)論您有什么樣的網(wǎng)站設(shè)計(jì)或者設(shè)計(jì)方案要求,我們都將富于創(chuàng)造性的提供專業(yè)設(shè)計(jì)服務(wù)并滿足您的需求。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() }}
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,的支持。