好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > laravel手動創建數組分頁的實現代碼

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

熱門標簽:哈爾濱400電話辦理到易號網 智能外呼電銷系統 沈陽人工智能電銷機器人公司 拉薩打電話機器人 寶安400電話辦理 h5 地圖標注 高識別電銷機器人 合肥外呼系統app 電銷機器人-快迭智能

本文介紹了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()方法獲取每頁要顯示的數據。

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

您可能感興趣的文章:
  • Laravel5.5 手動分頁和自定義分頁樣式的簡單實現
  • PHP框架Laravel插件Pagination實現自定義分頁
  • laravel自定義分頁效果
  • laravel自定義分頁的實現案例offset()和limit()
  • laravel實現分頁樣式替換示例代碼(增加首、尾頁)
  • Laravel手動分頁實現方法詳解
  • Laravel+jQuery實現AJAX分頁效果
  • Laravel框架執行原生SQL語句及使用paginate分頁的方法
  • Laravel框架自定義分頁樣式操作示例

標簽:梅州 威海 張家口 林芝 巴中 山東 泰州 成都

巨人網絡通訊聲明:本文標題《laravel手動創建數組分頁的實現代碼》,本文關鍵詞  laravel,手動,創建,數組,分頁,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《laravel手動創建數組分頁的實現代碼》相關的同類信息!
  • 本頁收集關于laravel手動創建數組分頁的實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 97香蕉超级碰碰久久兔直播节目| 68日本xxxⅹxxxxx18| 国产精品久久久久久久午夜片| 日本工番口番H漫画人妻| 婷婷色在线| 老师真嫩真紧好爽20p图图| 中国女人与黑人做爰视频| 日韩欧美**字幕| 亚洲精品一区二区三区新线路| 男的舔女的逼| 性xxxx18公交车| 国产第二十三页浮力影院| 精品国产丝袜黑色高跟鞋| 巜人妻公侵犯波多野结什么销售| 国产情精品嫩草影院88av| 富裕县| 欧美精品九九99久久在免费线,| 看黄色一级视频| 欧日韩不卡在线视频| 美国A片巜禁忌3| 曰的好深好爽| 亚洲色图3p| 高潮抽搐失禁大喷水尖叫| 黄色欧美视频在线观看| 好吊色视频在线观看| 色欲XXOO久久久精产国品| 电影一级二级三级是怎么分出来的 | 性xxxx18免费观看| 中国成人在线视频| 啊嗯不要了| 免费观看美女裸色??视频软件| 野战好大好紧好爽好硬| 强迫臣服霍莽蓝晚| 黄色片视频网站| 久久精品电影院| 天天躁日日躁白天躁晚上躁 | 亚洲18国产学生在线观看| 成人人人人人欧美片做爰| 杨门女将肉艳史全文阅| ririai66在线播放| 亲爱的老师韩国5|