laravel自定义分页效果
author:一佰互联 2019-04-26   click:175

对于laravel分页,自带一个paginate的方法,很好用,但是也是有局限性的。

所以自己针对于此写了一个自己的分页,具体代码如下

<?php  namespace ...;use ...;/** * 自定义分页类,适合少数据的查询,多数据的时候不推荐 * Class CustomPaginate * @package AppToolsPaginate */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;  }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持网页设计。