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()方法获取每页要显示的数据。

相关文章
相关标签/搜索