本文介紹了laravel手動(dòng)創(chuàng)建數(shù)組分頁(yè)的實(shí)現(xiàn)代碼,分享給大家,具體如下:
laravel分頁(yè)功能:
有幾種方法可以對(duì)數(shù)據(jù)進(jìn)行分頁(yè)。最簡(jiǎn)單的是在 [查詢(xún)語(yǔ)句構(gòu)造器] 或 [Eloquent 查詢(xún)] 中使用 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í)行更高效的查詢(xún)。
- 目前,Laravel 無(wú)法高效執(zhí)行使用 groupBy 語(yǔ)句的分頁(yè)操作。如果你需要在分頁(yè)結(jié)果集中使用 groupBy,建議你查詢(xún)數(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)有寫(xiě)如何自己使用分頁(yè)類(lèi)去分頁(yè)了,但沒(méi)有 詳細(xì)說(shuō)明。
手動(dòng)創(chuàng)建分頁(yè)
如果你想手動(dòng)創(chuàng)建分頁(yè)實(shí)例并且最終得到一個(gè)數(shù)組類(lèi)型的結(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類(lèi),并傳入對(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
類(lèi)并傳入必要的參數(shù),根據(jù)每頁(yè)的條數(shù)利用array_slice()方法獲取每頁(yè)要顯示的數(shù)據(jù)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- Laravel5.5 手動(dòng)分頁(yè)和自定義分頁(yè)樣式的簡(jiǎn)單實(shí)現(xiàn)
- PHP框架Laravel插件Pagination實(shí)現(xiàn)自定義分頁(yè)
- laravel自定義分頁(yè)效果
- laravel自定義分頁(yè)的實(shí)現(xiàn)案例offset()和limit()
- laravel實(shí)現(xiàn)分頁(yè)樣式替換示例代碼(增加首、尾頁(yè))
- Laravel手動(dòng)分頁(yè)實(shí)現(xiàn)方法詳解
- Laravel+jQuery實(shí)現(xiàn)AJAX分頁(yè)效果
- Laravel框架執(zhí)行原生SQL語(yǔ)句及使用paginate分頁(yè)的方法
- Laravel框架自定義分頁(yè)樣式操作示例