thinkphp5框架前后端分离项目实现分页功能的方法分析


Posted in PHP onOctober 08, 2019

本文实例讲述了thinkphp5框架前后端分离项目实现分页功能的方法。分享给大家供大家参考,具体如下:

方法一

利用tp5提供的paginate方法实现自动分页

参数

page第几页,paginate分页方法会自动获取

size  每页数量

代码

/**
* Notes:消费记录
* Date: 2019/6/25
* Time: 15:43
* @param Request $request
* @return \think\response\Json
*/
public function getMyConsumeLog(Request $request)
{
    global $_W;
    $size = $request->param('size', 6);
    $list = $this->model->getListByMid($_W['user']['id'],$size);
    return json(['data' => $list, 'error' => 0, 'message' => 'success']);
}
public function getListByMid($mid,$size = 10){
    $res = $this
      ->alias('c')
      ->field('c.*,b.book_name,b.book_flash,s.section_title')
      ->leftJoin('booksection s','c.chapter_id = s.id')
      ->leftJoin('book b','s.book_id = b.id')
      ->where('c.mid',$mid)
      ->order('c.id desc')
      ->paginate($size);
    return $res;
}

返回数据

{
    "data": {
        "total": 1,
        "per_page": 1,
        "current_page": 1,
        "last_page": 1,
        "data": [
            {
                "id": 105,
                "mid": 55,
                "book_id": 31,
                "chapter_id": 46046,
                "score": 27,
                "create_time": 1561447448,
                "book_name": "桃运村支书",
                "book_flash": "https://cdnxiaoshuo.t.com/FiO6TM0N4kpzKB7tqrDko64ZS4H4",
                "section_title": "第29章 康庄大道"
            }
        ]
    },
    "error": 0,
    "message": "success"
}

方法二

利用limit方法

$curr_page = $request->param('page', 1);
    $size = $request->param('size', 6);
$list = $consume_model->getListByWhere($curr_page, $size, $where);
    $num = $consume_model->getListByWhereCount($where);
    return json(['data' => $list,'num' => $num,'error' => 0, 'message' => 'success']);
public function getListByWhere($curr_page,$limit = 10,$where = null){
    $res = $this
      ->alias('c')
      ->field('c.*,b.book_name,s.section_title')
      ->leftJoin('booksection s','c.chapter_id = s.id')
      ->leftJoin('book b','s.book_id = b.id')
      ->where($where)
      ->order('c.id desc')
      ->limit($limit*($curr_page - 1),$limit)
      ->select()
      ->toArray();
    return $res;
}
public function getListByWhereCount($where = null){
    $count = $this
      ->alias('c')
      ->where($where)
      ->count();
    return $count;
}

返回值

{
    "data": [
        {
            "id": 2,
            "mid": 4,
            "book_id": 4,
            "chapter_id": 22,
            "score": 30,
            "create_time": 0,
            "book_name": "复仇者联盟I",
            "section_title": "第11章  你是睡"
        },
        {
            "id": 1,
            "mid": 4,
            "book_id": 29,
            "chapter_id": 34,
            "score": 20,
            "create_time": 1598999,
            "book_name": "复仇者联盟II",
            "section_title": "第11章  你是睡"
        }
    ],
    "num": 2,
    "total_coin": 50,
    "error": 0,
    "message": "success"
}

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
PHP支持多种格式图片上传(支持jpg、png、gif)
Nov 03 PHP
php数组函数序列之array_flip() 将数组键名与值对调
Nov 07 PHP
PHP中通过HTTP_USER_AGENT判断是否为手机移动终端的函数代码
Feb 14 PHP
深入PHP数据加密详解
Jun 18 PHP
php缩小png图片不损失透明色的解决方法
Dec 25 PHP
使用Composer安装Yii框架的方法
Mar 15 PHP
ThinkPHP静态缓存简单配置和使用方法详解
Mar 23 PHP
thinkPHP2.1自定义标签库的导入方法详解
Jul 20 PHP
详解php中 === 的使用
Oct 24 PHP
PHP实现电商订单自动确认收货redis队列
May 17 PHP
php表单习惯用的正则表达式
Oct 11 PHP
laravel框架中路由设置,路由参数和路由命名实例分析
Nov 23 PHP
PHP7 安装event扩展的实现方法
Oct 08 #PHP
thinkphp5+layui实现的分页样式示例
Oct 08 #PHP
调试php程序的简单步骤
Oct 04 #PHP
用php定义一个数组最简单的方法
Oct 04 #PHP
php输出文字乱码的解决方法
Oct 04 #PHP
PHP 多进程与信号中断实现多任务常驻内存管理实例方法
Oct 04 #PHP
使用laravel和ajax实现整个页面无刷新的操作方法
Oct 03 #PHP
You might like
PHP生成随机数的方法实例分析
2015/01/22 PHP
PHP常见漏洞攻击分析
2016/02/21 PHP
Laravel5权限管理方法详解
2016/07/26 PHP
动态表单验证的操作方法和TP框架里面的ajax表单验证
2017/07/19 PHP
phpinfo的知识点总结
2019/10/10 PHP
IE中createElement需要注意的一个问题
2010/07/13 Javascript
JS获取url链接字符串 location.href
2013/12/23 Javascript
jQuery实现大转盘抽奖活动仿QQ音乐代码分享
2015/08/21 Javascript
jQuery实现美观的多级动画效果菜单代码
2015/09/06 Javascript
jQuery内容折叠效果插件用法实例分析(附demo源码)
2016/04/28 Javascript
JS实现的打字机效果完整实例
2016/06/20 Javascript
BootStrap实现轮播图效果(收藏)
2016/12/30 Javascript
Js实现中国公民身份证号码有效性验证实例代码
2017/05/03 Javascript
vue 项目 iOS WKWebView 加载
2019/04/17 Javascript
JavaScript队列结构Queue实现过程解析
2020/03/07 Javascript
基于canvasJS在PHP中制作动态图表
2020/05/30 Javascript
JS代码简洁方式之函数方法详解
2020/07/28 Javascript
JavaScript async/await原理及实例解析
2020/12/02 Javascript
[01:10]DOTA2次级职业联赛 - EP战队宣传片
2014/12/01 DOTA
Python中的左斜杠、右斜杠(正斜杠和反斜杠)
2016/08/30 Python
python3获取当前目录的实现方法
2019/07/29 Python
python 进程的几种创建方式详解
2019/08/29 Python
Python爬取豆瓣数据实现过程解析
2020/10/27 Python
python调用win32接口进行截图的示例
2020/11/11 Python
python re.match()用法相关示例
2021/01/27 Python
《小白兔和小灰兔》教学反思
2014/02/18 职场文书
师范生自荐信模板
2014/05/28 职场文书
销售行政专员岗位职责
2014/06/10 职场文书
岗位安全生产责任书
2014/07/28 职场文书
政治学专业毕业生求职信
2014/08/11 职场文书
2015年五四青年节活动总结
2015/02/10 职场文书
2015年招商引资工作总结
2015/04/25 职场文书
聘任书格式及范文
2015/09/21 职场文书
redis 限制内存使用大小的实现
2021/05/08 Redis
MySQL数据库中varchar类型的数字比较大小的方法
2021/11/17 MySQL
提高系统的吞吐量解决数据库重复写入问题
2022/04/23 MySQL