thinkphp分页实现效果


Posted in PHP onOctober 13, 2016

对于thinkphp分页的实现效果,一共分为两种一种是一种调用公共函数中的函数方法,而另一种是模型中书写分页的方法,下面就给需要的朋友来整理一下。

一、分页方法

/**
 * TODO 基础分页的相同代码封装,使前台的代码更少
 * @param $m 模型,引用传递
 * @param $where 查询条件
 * @param int $pagesize 每页查询条数
 * @return \Think\Page
 */
function getpage(&$m,$where,$pagesize=10){
 $m1=clone $m;//浅复制一个模型
 $count = $m->where($where)->count();//连惯操作后会对join等操作进行重置
 $m=$m1;//为保持在为定的连惯操作,浅复制一个模型
 $p=new Think\Page($count,$pagesize);
 $p->lastSuffix=false;
 $p->setConfig('header','<li class="rows">共<b>%TOTAL_ROW%</b>条记录  每页<b>%LIST_ROW%</b>条  第<b>%NOW_PAGE%</b>页/共<b>%TOTAL_PAGE%</b>页</li>');
 $p->setConfig('prev','上一页');
 $p->setConfig('next','下一页');
 $p->setConfig('last','末页');
 $p->setConfig('first','首页');
 $p->setConfig('theme','%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END% %HEADER%');

 $p->parameter=I('get.');

 $m->limit($p->firstRow,$p->listRows);

 return $p;
}

getpage方法可以放在TP框架的 Application/Common/Common/function.php,这个文档可以专门放置一些通用的方法,在哪里都可以调用(如:Controller文件,View文件等)。

二、调用分页方法

$m=M('products');
$p=getpage($m,$where,10);
$list=$m->field(true)->where($where)->order('id desc')->select();
$this->list=$list;
$this->page=$p->show();

再是View代码

<div class="pagination">
{$page}
</div>

三、最后就是分页的样式了,这个有些乱,因后台框架网上下载的,样式还没来的及整理,这个样式也可以自己实现,简单的。

.pagination ul {
 display: inline-block;
 margin-bottom: 0;
 margin-left: 0;
 -webkit-border-radius: 3px;
 -moz-border-radius: 3px;
 border-radius: 3px;
 -webkit-box-shadow: 0 1px 2px rgba(0,0,0,0.05);
 -moz-box-shadow: 0 1px 2px rgba(0,0,0,0.05);
 box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}
.pagination ul li {
 display: inline;
}

.pagination ul li.rows {
 line-height: 30px;
 padding-left: 5px;
}
.pagination ul li.rows b{color: #f00}

.pagination ul li a, .pagination ul li span {
 float: left;
 padding: 4px 12px;
 line-height: 20px;
 text-decoration: none;
 background-color: #fff;
 background: url('../images/bottom_bg.png') 0px 0px;
 border: 1px solid #d3dbde;
 /*border-left-width: 0;*/
 margin-left: 2px;
 color: #08c;
}
.pagination ul li a:hover{
 color: red;
 background: #0088cc;
}
.pagination ul li.first-child a, .pagination ul li.first-child span {
 border-left-width: 1px;
 -webkit-border-bottom-left-radius: 3px;
 border-bottom-left-radius: 3px;
 -webkit-border-top-left-radius: 3px;
 border-top-left-radius: 3px;
 -moz-border-radius-bottomleft: 3px;
 -moz-border-radius-topleft: 3px;
}
.pagination ul .disabled span, .pagination ul .disabled a, .pagination ul .disabled a:hover {
color: #999;
cursor: default;
background-color: transparent;
}
.pagination ul .active a, .pagination ul .active span {
color: #999;
cursor: default;
}
.pagination ul li a:hover, .pagination ul .active a, .pagination ul .active span {
background-color: #f0c040;
}
.pagination ul li.last-child a, .pagination ul li.last-child span {
 -webkit-border-top-right-radius: 3px;
 border-top-right-radius: 3px;
 -webkit-border-bottom-right-radius: 3px;
 border-bottom-right-radius: 3px;
 -moz-border-radius-topright: 3px;
 -moz-border-radius-bottomright: 3px;
}

.pagination ul li.current a{color: #f00 ;font-weight: bold; background: #ddd}
PHP 相关文章推荐
windows下zendframework项目环境搭建(通过命令行配置)
Dec 06 PHP
apache和php之间协同工作的配置经验分享
Apr 08 PHP
php.ini 配置文件的深入解析
Jun 17 PHP
解析php中array_merge与array+array的区别
Jun 21 PHP
preg_match_all使用心得分享
Jan 31 PHP
利用PHP脚本在Linux下用md5函数加密字符串的方法
Jun 29 PHP
YII2.0之Activeform表单组件用法实例
Jan 09 PHP
php添加数据到xml文件的简单例子
Sep 08 PHP
php 数组元素快速去重
May 05 PHP
PHP+ajax实现获取新闻数据简单示例
May 08 PHP
TP5(thinkPHP5)框架基于ajax与后台数据交互操作简单示例
Sep 03 PHP
php使用Swoole实现毫秒级定时任务的方法
Sep 04 PHP
php实现图片以base64显示的方法
Oct 13 #PHP
php实现将base64格式图片保存在指定目录的方法
Oct 13 #PHP
thinkphp隐藏index.php/home并允许访问其他模块的实现方法
Oct 13 #PHP
Mac版PhpStorm之XAMPP整合apache服务器配置的图文教程详解
Oct 13 #PHP
php结合ajax实现手机发红包的案例
Oct 13 #PHP
php加密解密字符串示例
Oct 13 #PHP
用php和jQuery来实现“顶”和“踩”的投票功能
Oct 13 #PHP
You might like
PHP4之COOKIE支持详解
2006/10/09 PHP
上传多个文件的PHP脚本
2006/11/26 PHP
献给php初学者(入门学习经验谈)
2010/10/12 PHP
优化WordPress中文章与评论的时间显示
2016/01/12 PHP
PHP内部实现打乱字符串顺序函数str_shuffle的方法
2019/02/14 PHP
Javascript 网页黑白效果实现代码(兼容IE/FF等)
2010/04/23 Javascript
js控制table合并具体实现
2014/02/20 Javascript
AngularJS入门教程之Hello World!
2014/12/06 Javascript
JS+DIV实现鼠标划过切换层效果的方法
2015/05/25 Javascript
jquery实现仿新浪微博评论滚动效果
2015/08/06 Javascript
Bootstrap 组件之按钮(二)
2016/05/11 Javascript
EasyUI中在表单提交之前进行验证
2016/07/19 Javascript
jQuery Easy UI中根据第一个下拉框选中的值设置第二个下拉框是否可以编辑
2016/11/29 Javascript
Javascript之面向对象--封装
2016/12/02 Javascript
vue2笔记 — vue-router路由懒加载的实现
2017/03/03 Javascript
js中toString()和String()区别详解
2017/03/23 Javascript
在vue项目中使用Nprogress.js进度条的方法
2018/01/31 Javascript
layui-table表复选框勾选的所有行数据获取的例子
2019/09/13 Javascript
Python线性方程组求解运算示例
2018/01/17 Python
Django基于ORM操作数据库的方法详解
2018/03/27 Python
python实现的MySQL增删改查操作实例小结
2018/12/19 Python
Python django框架应用中实现获取访问者ip地址示例
2019/05/17 Python
通过python改变图片特定区域的颜色详解
2019/07/15 Python
tensorflow实现打印ckpt模型保存下的变量名称及变量值
2020/01/04 Python
python 实现两个npy档案合并
2020/07/01 Python
Python读取Excel一列并计算所有对象出现次数的方法
2020/09/04 Python
AmazeUI折叠式卡片布局,整合内容列表、表格组件实现
2020/08/20 HTML / CSS
澳大利亚冲浪和时尚服装网上购物:SurfStitch
2017/07/29 全球购物
年度考核自我鉴定
2013/11/09 职场文书
医科大学毕业生自荐信
2014/02/03 职场文书
上班玩手机检讨书
2014/02/17 职场文书
幼儿园教师教育感言
2014/02/28 职场文书
国际政治学专业推荐信
2014/09/26 职场文书
优秀教师工作总结2015
2015/07/22 职场文书
创业项目(超低成本创业项目)
2019/08/16 职场文书
高中议论文(范文2篇)
2019/08/19 职场文书