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 相关文章推荐
跟我学小偷程序之成功偷取首页(第三天)
Oct 09 PHP
用PHP实现的四则运算表达式计算实现代码
Aug 02 PHP
phpmyadmin config.inc.php配置示例
Aug 27 PHP
php中cookie的使用方法
Mar 29 PHP
Laravel 4 初级教程之安装及入门
Oct 30 PHP
基于PHP实现商品成交时发送短信功能
May 11 PHP
PHP调用Mailgun发送邮件的方法
May 04 PHP
PHP设计模式之观察者模式定义与用法示例
Aug 04 PHP
PHP实现带进度条的Ajax文件上传功能示例
Jul 02 PHP
laravel-admin 实现给grid的列添加行数序号的方法
Oct 08 PHP
laravel5.1框架model类查询的实现方法
Oct 08 PHP
一文搞懂php的垃圾回收机制
Jun 18 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
ThinkPHP自定义函数解决模板标签加减运算的方法
2015/07/03 PHP
PHP receiveMail实现收邮件功能
2018/04/25 PHP
在IE中调用javascript打开Excel的代码(downmoon原作)
2007/04/02 Javascript
JavaScript实现判断图片是否加载完成的3种方法整理
2015/03/13 Javascript
jQuery实现的产品自动360度旋转展示特效源码分享
2015/08/21 Javascript
JavaScript判断数组是否存在key的简单实例
2016/08/03 Javascript
AngularJS 2.0入门权威指南
2016/10/08 Javascript
微信公众号 摇一摇周边功能开发
2016/12/08 Javascript
Angular组件化管理实现方法分析
2017/03/17 Javascript
JavaScript设计模式之代理模式详解
2017/06/09 Javascript
CheckBox多选取值及判断CheckBox选中是否为空的实例
2017/10/31 Javascript
基于layui轮播图满屏是高度自适应的解决方法
2019/09/16 Javascript
使用layui的layer组件做弹出层的例子
2019/09/27 Javascript
为什么推荐使用JSX开发Vue3
2020/12/28 Vue.js
[01:27:43]VGJ.S vs TNC Supermajor 败者组 BO3 第三场 6.6
2018/06/07 DOTA
使用Python编写一个模仿CPU工作的程序
2015/04/16 Python
python删除列表中重复记录的方法
2015/04/28 Python
python简单文本处理的方法
2015/07/10 Python
python 将md5转为16字节的方法
2018/05/29 Python
python中不能连接超时的问题及解决方法
2018/06/10 Python
python 将list转成字符串,中间用符号分隔的方法
2018/10/23 Python
在Python中实现替换字符串中的子串的示例
2018/10/31 Python
详解Python3 基本数据类型
2019/04/19 Python
python3.6中@property装饰器的使用方法示例
2019/08/17 Python
Python 添加文件注释和函数注释操作
2020/08/09 Python
python利用proxybroker构建爬虫免费IP代理池的实现
2021/02/21 Python
10个很棒的 CSS3 开发工具 推荐
2011/05/16 HTML / CSS
市场营销专业推荐信
2013/11/03 职场文书
《长相思》听课反思
2014/04/10 职场文书
小学教师个人先进事迹材料
2014/05/17 职场文书
改进作风怎么办发言材料
2014/08/17 职场文书
营销总监岗位职责
2014/09/16 职场文书
司法局群众路线教育实践活动整改措施
2014/09/17 职场文书
活动费用申请报告
2015/05/15 职场文书
法定代表人身份证明书
2015/06/18 职场文书
婚宴主持词
2015/06/30 职场文书