• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    laravel手动创建数组分页的实现代码

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

    laravel分页功能:

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

    paginate用法如下:

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

    效果如下:

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

    simplePaginate用法如下:

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

    效果如下:

    「上一页」 「下一页」

    注意:

    1. 如果你只需要在分页视图中显示简单的「下一页」和「上一页」的链接,即不需要显示每个页码的链接,更推荐使用 simplePaginate 方法来执行更高效的查询。
    2. 目前,Laravel 无法高效执行使用 groupBy 语句的分页操作。如果你需要在分页结果集中使用 groupBy,建议你查询数据库并手动创建分页器。

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

    这种情况可以采用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()方法获取每页要显示的数据。

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

    您可能感兴趣的文章:
    • Laravel5.5 手动分页和自定义分页样式的简单实现
    • PHP框架Laravel插件Pagination实现自定义分页
    • laravel自定义分页效果
    • laravel自定义分页的实现案例offset()和limit()
    • laravel实现分页样式替换示例代码(增加首、尾页)
    • Laravel手动分页实现方法详解
    • Laravel+jQuery实现AJAX分页效果
    • Laravel框架执行原生SQL语句及使用paginate分页的方法
    • Laravel框架自定义分页样式操作示例
    上一篇:thinkPHP框架实现生成条形码的方法示例
    下一篇:Laravel程序架构设计思路之使用动作类
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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