对于laravel分页,自带一个paginate的方法,很好用,但是也是有局限性的。
所以自己针对于此写了一个自己的分页,具体代码如下
功能简介:1.用户留言功能2.用户定货功能3.定制货货功能4.定制网页样式和其实设置(比如主页)5.强大的管理功能(现在的程序都是管理功能大于应用功能:)6.管理功能支持查看订货单,留言,分页,删除等功能管理页面:login.asp管理密码:admin
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;
}
}









