thinkphp5 api开发(thinkphp5框架前后端分离项目实现分页功能的方法分析)
thinkphp5 api开发
thinkphp5框架前后端分离项目实现分页功能的方法分析本文实例讲述了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程序设计有所帮助。
原文链接:https://blog.csdn.net/flysnownet/article/details/93624845
- mysql百万数据分页查询优化方案(MySQL单表亿级数据分页怎么优化?)
- easyui combogrid分页
- dedecsm模板中首页如何实现分页的三种方法比较分析(dedecsm模板中首页如何实现分页的三种方法比较分析)
- sqlserver创建带参数的存储过程(SQLServer存储过程实现单条件分页)
- laravel 前后端开发(在Laravel中实现使用AJAX动态刷新部分页面)
- vueelementui表格操作(Vue组件库ElementUI实现表格列表分页效果)
- mysql的limit的分页使用(获取 MySQL innodb B+tree 的高度的方法)
- dedecms列表分页代码(Dedecms文章设置推荐后列表页标题自动加粗的解决方法)
- laravel分页(laravel5.5添加echarts实现画图功能的方法)
- redis新增数据分页(Scrapy-Redis结合POST请求获取数据的方法示例)
- dedecms循环栏目(dedecms 栏目列表分页链接优化)
- dedecms分页修改(Dedecms图片加上Alt和Title等属性的修改方法)
- dedecms栏目内容怎么插入分页符(dedecms织梦让likearticle的mytypeid支持多个栏目和子栏目)
- thinkphp5.0实例详解(ThinkPHP5&5.1框架关联模型分页操作示例)
- sqlserver数据库如何分页(SQL server分页的4种方法示例很全面)
- sqlserver分页数据重复(SQL Server 在分页获取数据的同时获取到总记录数)
- 岳云鹏跟凤凰传奇谈心,说出了人生中最重要的三个人,这才成功(岳云鹏跟凤凰传奇谈心)
- 爱情可以当饭吃吗(爱情能当饭吃吗)
- Top 3 JSHS《运动与健康科学 英文 》跻身SCI体育学期刊世界前三(Top3JSHS运动与健康科学)
- 体坛传媒LOGO全新升级,多元发展迈出坚实步伐(体坛传媒LOGO全新升级)
- 超撩人治愈的绝美水彩,原来出自她之手 一笔一画令无数人沉醉(超撩人治愈的绝美水彩)
- 新手的勾线(新手的勾线)
热门推荐
- eval在python里面什么意思(python 为什么说eval要慎用)
- mysqldump备份缺点(MySQL5.7 mysqldump备份与恢复的实现)
- python在mysql创建数据库(python3对接mysql数据库实例详解)
- docker 加入k8s吗(k8s和Docker关系简单说明)
- php怎么判断是否有session(PHP中Session ID的实现原理实例分析)
- css3中一些常用的特效果(CSS3 制作的书本翻页特效)
- sql语句执行顺序
- js编写一个数组去重的方法(JS实现数组过滤从简单到多条件筛选)
- python用指针合并两个有序数组(Python3实现计算两个数组的交集算法示例)
- 网站服务器的带宽(网站服务器租用怎么选择合适的带宽和机器配置)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9