当前位置:首页 > CMS教程 > 其它CMS > 列表

laravel手动创建数组分页的实现代码

发布:smiling 来源: PHP粉丝网  添加日期:2021-09-25 15:07:19 浏览: 评论:0 

这篇文章主要介绍了laravel手动创建数组分页的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧。

本文介绍了laravel手动创建数组分页的实现代码,分享给大家,具体如下:

laravel分页功能:

有几种方法可以对数据进行分页,最简单的是在 [查询语句构造器] 或 [Eloquent 查询] 中使用 paginate 或 simplePaginate 方法。

paginate用法如下:

  1. //控制器中 
  2. $users = DB::table('users')->paginate(15); 
  3. return view('user.index', ['users' => $users]); 
  4.  
  5. //视图中 
  6. {{ $users->links() }} 

效果如下:

「上一页」 「1」「2」「3」 「下一页」

simplePaginate用法如下:

  1. //控制器中 
  2. $users = User::where('votes''>', 100)->simplePaginate(15); 
  3. return view('user.index', compact('users')); 
  4.  
  5. //视图中 
  6. {{ $users->links() }} 

效果如下:

「上一页」 「下一页」

注意:

如果你只需要在分页视图中显示简单的「下一页」和「上一页」的链接,即不需要显示每个页码的链接,更推荐使用 simplePaginate 方法来执行更高效的查询。

目前,Laravel 无法高效执行使用 groupBy 语句的分页操作。如果你需要在分页结果集中使用 groupBy,建议你查询数据库并手动创建分页器。

有时候可能会遇到这种情况,$dataA和$dataB是从数据库取出的两个不同的数据集合,需要同时将$dataA和$dataB分配到视图并进行分页展示,那这种情况怎么办呢?

这种情况可以采用laravel数组分页。

其实在laravel文档中已经有写如何自己使用分页类去分页了,但没有 详细说明。

手动创建分页

如果你想手动创建分页实例并且最终得到一个数组类型的结果,可以根据需求来创建 IlluminatePaginationPaginator 或者 IlluminatePaginationLengthAwarePaginator 实例来实现。

具体可以看IlluminatePaginationLengthAwarePaginator中的这段代码:

  1. public function __construct($items$total$perPage$currentPage = null, array $options = []) 
  2.  { 
  3.   foreach ($options as $key => $value) { 
  4.    $this->{$key} = $value
  5.   } 
  6.  
  7.   $this->total = $total
  8.   $this->perPage = $perPage
  9.   $this->lastPage = max((int) ceil($total / $perPage), 1); 
  10.   $this->path = $this->path !== '/' ? rtrim($this->path, '/') : $this->path; 
  11.   $this->currentPage = $this->setCurrentPage($currentPage$this->pageName); 
  12.   $this->items = $items instanceof Collection ? $items : Collection::make($items); 
  13.  } 

以下为具体实现代码:

  1. //控制器中 
  2. public function index(LiveService $liveService, Request $request
  3.  { 
  4.   //数据A 
  5.   $dataA = User::where('status', 1)->get()->toArray(); 
  6.   //数据B 
  7.   $dataB = User::where('status', 2)->get()->toArray(); 
  8.   $data = array_merge($dataA$dataB); 
  9.   //当前页数 默认1 
  10.   $page = $request->page ?: 1; 
  11.   //每页的条数 
  12.   $perPage = 4; 
  13.   //计算每页分页的初始位置 
  14.   $offset = ($page * $perPage) - $perPage
  15.    //实例化LengthAwarePaginator类,并传入对应的参数 
  16.   $data = new LengthAwarePaginator(array_slice($data$offset$perPage, true), count($data), $perPage
  17.    $page, ['path' => $request->url(), 'query' => $request->query()]); 
  18.   return view('admin.users.index', compact('data')); 
  19.  } 
  20.  
  21. //视图中 
  22. {{ $data->links() }} 

以上基本就完成了数组分页,大致流程就是控制器获取到当前页数,实例化LengthAwarePaginator类并传入必要的参数,根据每页的条数利用array_slice()方法获取每页要显示的数据。

Tags: laravel创建数组分页

分享到: