亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在laravel中手動創建一個數組分頁

發布時間:2021-03-19 17:02:36 來源:億速云 閱讀:255 作者:Leah 欄目:開發技術

怎么在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數組分頁。

其實在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() }}

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

遂溪县| 陈巴尔虎旗| 黑水县| 凤冈县| 松桃| 凤庆县| 清远市| 武平县| 珲春市| 永兴县| 任丘市| 安康市| 清徐县| 庆元县| 康定县| 罗平县| 车致| 鄂尔多斯市| 南川市| 乌恰县| 铁岭县| 海门市| 缙云县| 团风县| 福建省| 奉化市| 渭源县| 舟曲县| 兴业县| 洞头县| 锡林郭勒盟| 交城县| 中西区| 重庆市| 宜昌市| 平潭县| 武山县| 获嘉县| 女性| 芜湖市| 麦盖提县|