您好,登錄后才能下訂單哦!
這篇文章主要介紹laravel如何實現自定義分頁,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
對于laravel分頁,自帶一個paginate的方法,很好用,但是也是有局限性的。
所以自己針對于此寫了一個自己的分頁,具體代碼如下
<?php namespace ...; use ...; /** * 自定義分頁類,適合少數據的查詢,多數據的時候不推薦 * Class CustomPaginate * @package App\Tools\Paginate */ class CustomPaginate { /** * 自定義數組分頁 * @param $data = 返回結果 * @param $page * @param $limit * @return mixed */ public static function paginate($data, $page = 1, $limit = 10) { if (!is_numeric($page) || !is_numeric($limit)) { return false; } $count = count($data); $data = array_slice($data, ($page - 1) * $limit, $limit); return new LengthAwarePaginator($data, $count, $limit, $page); } /** * 參數解釋 對外暴露的方法 * @param $data = array|collection 切記只支持這兩種 * @param $page = 當前頁 * @param $limit = 每一頁展示幾條 * @return array|false * 返回結果為數組 * 調用實例: CustomPaginate::paginateToArray($data, $request->page, $request->limit); */ public static function paginateToArray($data, $page = 1, $limit = 10) { $isValidate = self::validate($data, $page, $limit); //驗證 if ($isValidate === false) { return false; } $res = self::paginate($data, $page, $limit)->toArray(); //分頁數據轉換為數組 //上一頁 || 下一頁 => path if ($res['prev_page_url'] != null) { $prev_page = $page - 1; $res['prev_page_url'] = Paginator::resolveCurrentPath() . "?page=" . $prev_page . "&limit=" . $limit; } if ($res['next_page_url'] != null) { $next_page = $page + 1; $res['next_page_url'] = Paginator::resolveCurrentPath() . "?page=" . $next_page . "&limit=" . $limit; } return $res; } /** * 驗證參數是否合法 */ public static function validate(&$data, &$page = 1, &$limit = 10) { $page = empty($page) ? 1 : $page; $limit = empty($limit) ? 10 : $limit; if (!is_array($data) && !$data instanceof Collection) { return false;//"自定義分頁方法只支持數組數據和集合數據"; } if (!is_numeric($page) || !is_numeric($limit)) { return false;//"page limit 參數只支持數字"; } if ($data instanceof Collection) { return $data = $data->toArray(); } return $data; } }
以上是“laravel如何實現自定義分頁”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。