thinkphp5框架前后端分离项目实现分页功能的方法分析
本文实例讲述了thinkphp5框架前后端分离项目实现分页功能的方法。分享给大家供大家参考,具体如下:
方法一
利用tp5提供的paginate方法实现自动分页
参数
page第几页,paginate分页方法会自动获取
size 每页数量
代码
/**
* Notes:消费记录
* Date: 2019/6/25
* Time: 15:43
* @param Request $request
* @return thinkresponseJson
*/
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相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- 详解在Linux中怎么使用cron计划任务
- Linux系统删除文件夹和文件的命令
- 详解Linux防火墙iptables禁IP与解封IP常用命令
- 在Ubuntu 16.04 Server上安装Zabbix的方法
- Centos7.3安装部署最新版Zabbix3.4的方法(图文)
- Linux系统下移植busybox中mkfs.vfat命令
- Linux服务器配置ip白名单防止远程登录以及端口暴露的问题
- Ubuntu上释放空间的5种简单方法
- Linux下Redis允许远程连接的实现方法
- Linux Socket 编程简介和实现
- Linux (Ubuntu 18.04) 下安装vim编辑器的方法
- 把windows下的字体安装到Linux系统下的方法介绍
- Ubuntu 7.10修改软件源的方法
- Linux 僵尸进程产生原因及解决方法
- Ubuntu17.04配置更换国内源的方法