thinkphp实现数组分页示例


Posted in PHP onApril 13, 2014

在thinkphp的框架下实现分页。公司的网站基于Thinkphp框架,一直久闻thinkphp的大名,终于有机会实战了。thinkphp是MVC架构的,MVC对于任何ITers来说都不陌生,模型(model)-视图(view)-控制器(controller)。他将逻辑和数据分开处理,少了很多繁琐的过程。其实在官方的资料中已经详细的介绍了怎么分页,传送门:http://document.thinkphp.cn/manual_3_2.html#data_page

可是并不适用于数据已经从DB中取出,并且转换为数组的情况,我接触PHP满打满算2个月,接触thinkphp不过3周。之前把很多时间花在了官方文档上,去熟悉thinkphp。也算是磨刀不误砍柴工吧。这里把官方文档当作比较进行阐述:

(只举文档上第一个方法):利用Page类和limit方法,代码如下:

$User = M('User'); // 实例化User对象
$count= $User->where('status=1')->count();// 查询满足要求的总记录数
$Page = new \Think\Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数(25)
$show = $Page->show();// 分页显示输出
// 进行分页数据查询 注意limit方法的参数要使用Page类的属性
$list = $User->where('status=1')->order('create_time')->limit($Page->firstRow.','.$Page->listRows)->select();
$this->assign('list',$list);// 赋值数据集
$this->assign('page',$show);// 赋值分页输出
$this->display(); // 输出模板

基本思想就是先计算总的记录数,然后根据所设置的每页显示的记录数来分页。使用Thinkphp封装好的Page类可以很方便的实现。实现的重点在第11行,limit方法就是按照一定的规则从查询数据中抽取数据。但是数据已经取出又怎么办呢?

我们用到了php自带的函数array_slice( )。定义在此:http://www.php.net/manual/en/function.array-slice.php

其实就是数组版的limit方法。好了,工具找到了,实现就很容易了。直接上代码:

public function nodeslist(){
$portal = new PortalApi;
$nodelist = $portal->getNodeLists($this->uid);$count = count($nodelist['data']);
$p = new Page($count,10);
$lists = array_slice($nodelist['data'], $p->firstRow,$p->listRows);
$page = $p->show();
$this->assign('page',$page);
$this->assign('nodes',$lists);
$this->display(); 
 }

代码有删减,只保留实现细节。

第3行getNodeLists方法从数据库中取出数据并赋值给数组nodelist。

第5行count计算出数组元素的个数。

第6行为Page类传入参数。

第7行的array_slice函数代替了limit方法。原理相同。

第9行用assign方法为模版赋值。定义在此:http://document.thinkphp.cn/manual_3_2.html#assign

第10行同理。

下面是view中的代码:

 <div class="page-list">
{$page}
 </div>

如果仅仅这样的话,显示出来的效果并不友好。再找出来Page类的定义:
// 分页显示定制
private $config= array(
'header' => '<span class="rows">共 %TOTAL_ROW% 条记录</span>',
'prev' => '上一页',
'next' => '下一页',
'first'=> '第一页',
'last' => '...%TOTAL_PAGE%',
'theme'=> '%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END%',

在页数前后加入空格。现在可以看效果了:

thinkphp实现数组分页示例

跟大背景还是挺配,当然,可以根据自己的情况设置不同的效果。

PHP 相关文章推荐
建立文件交换功能的脚本(二)
Oct 09 PHP
PHP安装攻略:常见问题解答(三)
Oct 09 PHP
整理的一些实用WordPress后台MySQL操作命令
Jan 07 PHP
深入PHP5中的魔术方法详解
Jun 17 PHP
国外十大最流行的PHP框架排名
Jul 04 PHP
PHP函数之日期时间函数date()使用详解
Sep 09 PHP
php的array数组和使用实例简明教程(容易理解)
Mar 20 PHP
ThinkPHP3.1新特性之命名范围的使用
Jun 19 PHP
ThinkPHP采用GET方式获取中文参数查询无结果的解决方法
Jun 26 PHP
初识php MVC
Sep 10 PHP
php中session与cookie的比较
Jan 27 PHP
php实现判断访问来路是否为搜索引擎机器人的方法
Apr 15 PHP
不使用php api函数实现数组的交换排序示例
Apr 13 #PHP
php读取大文件示例分享(文件操作类)
Apr 13 #PHP
php使用smtp发送支持附件的邮件示例
Apr 13 #PHP
php实现上传图片生成缩略图示例
Apr 13 #PHP
php使用curl和正则表达式抓取网页数据示例
Apr 13 #PHP
PHP header()函数常用方法总结
Apr 11 #PHP
开源php中文分词系统SCWS安装和使用实例
Apr 11 #PHP
You might like
利用递归把多维数组转为一维数组的函数
2006/10/09 PHP
PHP 选项及相关信息函数库
2006/12/04 PHP
php设置session值和cookies的学习示例
2014/03/21 PHP
PHP substr()函数参数解释及用法讲解
2017/11/23 PHP
扩展String功能方法
2006/09/22 Javascript
比Jquery的document.ready更快的方法
2010/04/28 Javascript
IE图片缓存document.execCommand(&quot;BackgroundImageCache&quot;,false,true)
2011/03/01 Javascript
简单的jquery左侧导航栏和页面选中效果
2014/08/21 Javascript
浅谈JavaScript Array对象
2014/12/29 Javascript
JS实现页面超时后自动跳转到登陆页面
2015/01/19 Javascript
JSON格式的键盘编码对照表
2015/01/29 Javascript
JS+CSS实现简易的滑动门效果代码
2015/09/24 Javascript
js+div+css下拉导航菜单完整代码分享
2016/12/28 Javascript
React利用插件和不用插件实现双向绑定的方法详解
2017/07/03 Javascript
JavaScript无操作后屏保功能的实现方法
2017/07/04 Javascript
Angular 2父子组件数据传递之@Input和@Output详解 (上)
2017/07/05 Javascript
JavaScript实现短暂提示框功能
2018/04/04 Javascript
react 中父组件与子组件双向绑定问题
2019/05/20 Javascript
Js和VUE实现跑马灯效果
2020/05/25 Javascript
python单元测试unittest实例详解
2015/05/11 Python
用python记录运行pid,并在需要时kill掉它们的实例
2017/01/16 Python
python:socket传输大文件示例
2017/01/18 Python
python3.6编写的单元测试示例
2019/08/17 Python
Python-jenkins 获取job构建信息方式
2020/05/12 Python
Django中F函数的使用示例代码详解
2020/07/06 Python
MADE荷兰:提供原创设计师家具
2018/04/03 全球购物
澳大利亚领先的时尚内衣零售商:Bras N Things
2020/07/28 全球购物
秋游活动策划方案
2014/02/16 职场文书
小学生感恩演讲稿
2014/04/25 职场文书
学校课外活动总结
2014/05/08 职场文书
大学生活动总结模板
2014/07/02 职场文书
中小学校园安全广播稿
2014/09/29 职场文书
教师个人成长总结
2015/02/11 职场文书
2016大一新生军训感言
2015/12/08 职场文书
css3实现背景图片半透明内容不透明的方法示例
2021/04/13 HTML / CSS
Mysql中@和@@符号的详细使用指南
2022/06/05 MySQL