laravel手動建立數組分頁

圖片描述

laravel分頁功能:laravel

有幾種方法能夠對數據進行分頁。最簡單的是在 [查詢語句構造器] 或 [Eloquent 查詢] 中使用 paginate 或 simplePaginate 方法。 數據庫

paginate用法以下:數組

//控制器中
$users = DB::table('users')->paginate(15);
return view('user.index', ['users' => $users]);

//視圖中
{{ $users->links() }}

效果以下:this

「上一頁」 「1」「2」「3」 「下一頁」url

simplePaginate用法以下:spa

//控制器中
$users = User::where('votes', '>', 100)->simplePaginate(15);
return view('user.index', compact('users'));

//視圖中
{{ $users->links() }}

效果以下:code

「上一頁」 「下一頁」 圖片

注意:文檔

  1. 若是你只須要在分頁視圖中顯示簡單的「下一頁」和「上一頁」的連接,即不須要顯示每一個頁碼的連接,更推薦使用 simplePaginate 方法來執行更高效的查詢。
  2. 目前,Laravel 沒法高效執行使用 groupBy 語句的分頁操做。若是你須要在分頁結果集中使用 groupBy,建議你查詢數據庫並手動建立分頁器。

有時候可能會遇到這種狀況,$dataA和$dataB是從數據庫取出的兩個不一樣的數據集合,須要同時將$dataA和$dataB分配到視圖並進行分頁展現,那這種狀況怎麼辦呢?get

圖片描述

這種狀況能夠採用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()方法獲取每頁要顯示的數據。

相關文章
相關標籤/搜索