ThinkPHP3.2.3实现分页的方法详解


Posted in PHP onJune 03, 2016

本文实例讲述了ThinkPHP3.2.3实现分页的方法。分享给大家供大家参考,具体如下:

首先要搞清楚的就是ThinkPHP3.2.3的分页类已经被移到了Think\Page.class.php,这是跟以前的版本有些不一样的,使用起来还是跟以前版本差不多,但是默认的效果不敢恭维,所以最好是自己加些样式。

我加了一些样式(不怎么好看),大家可以自行的再去改进分页样式,效果图:

ThinkPHP3.2.3实现分页的方法详解

在这里我有先把page的设置做成了一个函数getpage,将这个方法放到Application\Common\Common\function.php(注意function不是类)中方便其他地方调用,代码如下:

<?php
/**
 * TODO 基础分页的相同代码封装,使前台的代码更少
 * @param $count 要分页的总记录数
 * @param int $pagesize 每页查询条数
 * @return \Think\Page
 */
function getpage($count, $pagesize = 10) {
  $p = new Think\Page($count, $pagesize);
  $p->setConfig('header', '<li class="rows">共<b>%TOTAL_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->lastSuffix = false;//最后一页不显示为总页数
  return $p;
}
?>

控制器中使用的代码如下:

public function showAllUsers() {
    $m = M('User');
    $where = "id>10";
    $count = $m->where($where)->count();
    $p = getpage($count,1);
    $list = $m->field(true)->where($where)->order('id')->limit($p->firstRow, $p->listRows)->select();
    $this->assign('select', $list); // 赋值数据集
    $this->assign('page', $p->show()); // 赋值分页输出
    $this->display();
}

接下来在View中的使用:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>用户信息输出</title>
    <link href="__ROOT__/Public/Css/style.css" rel="stylesheet" type="text/css" />
    <link href="__ROOT__/Public/Css/mypage.css" rel="stylesheet" type="text/css"/>
  </head>
  <body>
    <table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor="#FFFFFF">
      <tr>
        <td colspan="3" bgcolor="#FFFFFF" class="title" align="center">当前登录用户:{$Think.session.admin}</td>
      </tr>
      <tr>
        <td colspan="3" bgcolor="#FFFFFF" class="title" align="center">用户信息</td>
      </tr>
      <tr class="title">
        <td bgcolor="#FFFFFF" width="44">ID</td>
        <td bgcolor="#FFFFFF" width="120">用户名</td>
        <td bgcolor="#FFFFFF" width="223">密码</td>
      </tr>
      <foreach name='select' item='user' >
        <tr class="content">
          <td bgcolor="#FFFFFF"> {$user.id}</td>
          <td bgcolor="#FFFFFF"> {$user.account}</td>
          <td bgcolor="#FFFFFF"> {$user.pwd}</td>
        </tr>
      </foreach>
      <tr class="content">
        <!--<td colspan="3" bgcolor="#FFFFFF"> {$page}</td>-->
        <td colspan="3" bgcolor="#FFFFFF"><div class="pages">
            {$page}
        </div></td>
      </tr>
    </table>
  </body>
</html>

其中设置分页的样式mypage.css,如下:

.pages a,.pages span {
  display:inline-block;
  padding:2px 5px;
  margin:0 1px;
  border:1px solid #f0f0f0;
  -webkit-border-radius:3px;
  -moz-border-radius:3px;
  border-radius:3px;
}
.pages a,.pages li {
  display:inline-block;
  list-style: none;
  text-decoration:none; color:#58A0D3;
}
.pages a.first,.pages a.prev,.pages a.next,.pages a.end{
  margin:0;
}
.pages a:hover{
  border-color:#50A8E6;
}
.pages span.current{
  background:#50A8E6;
  color:#FFF;
  font-weight:700;
  border-color:#50A8E6;
}

这样就可以了。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
PHP学习之PHP运算符
Oct 09 PHP
PHP简洁函数小结
Aug 12 PHP
PHP APC缓存配置、使用详解
Mar 06 PHP
php求正负数数组中连续元素最大值示例
Apr 11 PHP
PHP生成自适应大小的缩略图类及使用方法分享
May 06 PHP
php导出中文内容excel文件类实例
Jul 06 PHP
UTF-8正则表达式如何匹配汉字
Aug 03 PHP
分析PHP中单双引号的误区和双引号小隐患
Jul 19 PHP
php中输出json对象的值(实现方法)
Mar 07 PHP
PHP代码重构方法漫谈
Apr 17 PHP
php微信公众号开发之答题连闯三关
Oct 20 PHP
phpQuery采集网页实现代码实例
Apr 02 PHP
php for 循环使用的简单实例
Jun 02 #PHP
Yii多表联合查询操作详解
Jun 02 #PHP
既简单又安全的PHP验证码 附调用方法
Jun 02 #PHP
yii2分页之实现跳转到具体某页的实例代码
Jun 02 #PHP
[原创]php实现子字符串位置相互对调互换的方法
Jun 02 #PHP
PHP处理数组和XML之间的互相转换
Jun 02 #PHP
PHP邮箱验证示例教程
Jun 01 #PHP
You might like
查找php配置文件php.ini所在路径的二种方法
2014/05/26 PHP
php获取网页里所有图片并存入数组的方法
2015/04/06 PHP
Laravel 5框架学习之向视图传送数据
2015/04/08 PHP
php简单统计字符串单词数量的方法
2015/06/19 PHP
yii2使用ajax返回json的实现方法
2016/05/14 PHP
Laravel获取所有的数据库表及结构的方法
2019/10/10 PHP
PHP 图片合成、仿微信群头像的方法示例
2019/10/25 PHP
PHP7创建COOKIE和销毁COOKIE的实例方法
2020/02/03 PHP
JS版网站风格切换实例代码
2008/10/06 Javascript
input输入框的自动匹配(原生代码)
2013/03/19 Javascript
仿当当网淘宝网等主流电子商务网站商品分类导航菜单
2013/09/25 Javascript
JS基于cookie实现来宾统计记录访客信息的方法
2015/08/04 Javascript
使用堆实现Top K算法(JS实现)
2015/12/25 Javascript
Highcharts使用简例及异步动态读取数据
2015/12/30 Javascript
jquery跟随屏幕滚动效果的实现代码
2016/04/13 Javascript
为JQuery EasyUI 表单组件增加焦点切换功能的方法
2017/04/13 jQuery
详解react-router如何实现按需加载
2017/06/15 Javascript
vue数据双向绑定的注意点
2017/06/23 Javascript
js动态添加表格逐行添加、删除、遍历取值的实例代码
2018/01/25 Javascript
js装饰设计模式学习心得
2018/02/17 Javascript
Bootstrap Table实现定时刷新数据的方法
2018/08/13 Javascript
微信小程序自定义导航栏实例代码
2019/04/05 Javascript
Python基础教程之正则表达式基本语法以及re模块
2016/03/25 Python
Python AES加密模块用法分析
2017/05/22 Python
PyQt5实现下载进度条效果
2018/04/19 Python
VSCode Python开发环境配置的详细步骤
2019/02/22 Python
浅谈python中get pass用法
2019/03/19 Python
Django中Aggregation聚合的基本使用方法
2020/07/09 Python
基于Python-turtle库绘制路飞的草帽骷髅旗、美国队长的盾牌、高达的源码
2021/02/18 Python
css3学习之2D转换功能详解
2016/12/23 HTML / CSS
关于前端上传文件全面基础扫盲贴(入门)
2019/08/01 HTML / CSS
墨西哥网上购物:Linio墨西哥
2016/10/20 全球购物
英国最专业的健身器材供应商之一:Best Gym Equipment
2017/12/22 全球购物
佳能加拿大网上商店:Canon eStore Canada
2018/04/04 全球购物
非功能性需求都包括哪些方面
2013/10/29 面试题
市场营销专业推荐信
2013/11/03 职场文书