激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - laravel手動創建數組分頁的實現代碼

laravel手動創建數組分頁的實現代碼

2019-09-28 12:54promise PHP教程

這篇文章主要介紹了laravel手動創建數組分頁的實現代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

本文介紹了laravel手動創建數組分頁的實現代碼,分享給大家,具體如下:

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() }}

效果如下:

「上一頁」 「下一頁」

注意:

  1. 如果你只需要在分頁視圖中顯示簡單的「下一頁」和「上一頁」的鏈接,即不需要顯示每個頁碼的鏈接,更推薦使用 simplePaginate 方法來執行更高效的查詢。
  2. 目前,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()方法獲取每頁要顯示的數據。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人免费激情视频 | 欧美成人精品一区二区三区 | 亚洲精品无码不卡在线播放he | 久久99精品久久久久久秒播放器 | 国产一区二区在线观看视频 | 久久久久久久久久亚洲精品 | 91色一区二区三区 | 4p嗯啊巨肉寝室调教男男视频 | 在线观看视频日本 | 91精品欧美一区二区三区 | 中国美女一级黄色大片 | 亚洲国产精品久久久久久久久久久 | 亚洲特黄 | 国产一区二区三区视频在线观看 | 538在线精品 | 91看片免费看 | 久久人体 | 九九夜夜 | 在线亚洲免费 | hd极品free性xxx一护士 | 久久艹艹艹| aa国产视频一区二区 | 成人啪啪色婷婷久 | 久久国产精品二国产精品 | 成人免费在线视频 | 色吧综合网| 国产一区二区三区色淫影院 | 久久久精品视 | 九九热在线免费观看视频 | 精品国产91久久久久久 | 成人羞羞视频在线观看免费 | 欧美黄色视屏 | 青青草免费观看 | 蜜桃网在线| 亚洲卡通动漫在线观看 | 欧美 中文字幕 | 国产激爽大片在线播放 | 国产毛片网 | 草莓福利社区在线 | 国产精品99精品 | 欧美18一19sex性护士农村 |