Thinkphp3.2.3分页使用实例解析


Posted in PHP onJuly 28, 2016

首先要搞清楚的就是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;
}

这样就可以了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
8个出色的WordPress SEO插件收集
Feb 26 PHP
php设计模式 Singleton(单例模式)
Jun 26 PHP
Sorting Array Values in PHP(数组排序)
Sep 15 PHP
PHP中mb_convert_encoding与iconv函数的深入解析
Jun 21 PHP
php生成扇形比例图实例
Nov 06 PHP
CI(CodeIgniter)框架中的增删改查操作
Jun 10 PHP
PHP @ at 记号的作用示例介绍
Oct 10 PHP
php字符串截取函数用法分析
Nov 25 PHP
PHP判断上传文件类型的解决办法
Oct 20 PHP
PHP5.5迭代生成器用法实例详解
Mar 16 PHP
Symfony控制层深入详解
Mar 17 PHP
PHP基于单例模式编写PDO类的方法
Sep 13 PHP
thinkphp3.2.3 分页代码分享
Jul 28 #PHP
php实现带读写分离功能的MySQL类完整实例
Jul 28 #PHP
PHP实现带重试功能的curl连接示例
Jul 28 #PHP
php使用strip_tags()去除html标签仍有空白的解决方法
Jul 28 #PHP
php倒计时出现-0情况的解决方法
Jul 28 #PHP
24条货真价实的PHP代码优化技巧
Jul 28 #PHP
php求今天、昨天、明天时间戳的简单实现方法
Jul 28 #PHP
You might like
MYSQL环境变量设置方法
2007/01/15 PHP
PHP连接sql server 2005环境配置及问题解决
2014/08/08 PHP
WordPress中用于获取文章作者与分类信息的方法整理
2015/12/17 PHP
php实现生成验证码实例分享
2016/04/10 PHP
zen_cart实现支付前生成订单的方法
2016/05/06 PHP
实现PHP搜索加分页
2016/10/12 PHP
php 解析xml 的四种方法详细介绍
2016/10/26 PHP
PHP7 新增常量
2021/03/09 PHP
jQuery DIV弹出效果实现代码
2009/07/03 Javascript
HTA版JSMin(省略修饰语若干)基于javascript语言编写
2009/12/24 Javascript
js constructor的实际作用分析
2011/11/15 Javascript
jQuery实现加入购物车飞入动画效果
2015/03/14 Javascript
JS实现密码框根据焦点的获取与失去控制文字的消失与显示效果
2015/11/26 Javascript
微信小程序wx.request实现后台数据交互功能分析
2017/11/25 Javascript
JavaScript实现图片上传并预览并提交ajax
2019/09/30 Javascript
在Express中提供静态文件的实现方法
2019/10/17 Javascript
vue动画—通过钩子函数实现半场动画操作
2020/08/09 Javascript
JavaScript实现简单验证码
2020/08/24 Javascript
小程序实现tab标签页
2020/11/16 Javascript
Python求解平方根的方法
2015/03/11 Python
python类:class创建、数据方法属性及访问控制详解
2016/07/25 Python
python实现决策树分类
2018/08/30 Python
python进阶之自定义可迭代的类
2019/08/20 Python
python实现学生成绩测评系统
2020/06/22 Python
Sasa莎莎海外旗舰店:香港莎莎美妆平台
2018/03/21 全球购物
Coltorti Boutique官网:来自意大利的设计师品牌买手店
2018/11/09 全球购物
应用服务器有那些
2012/01/19 面试题
js正则匹配markdown里的图片标签的实现
2021/03/24 Javascript
校园公益广告语
2014/03/13 职场文书
垃圾桶标语
2014/06/24 职场文书
党的群众路线对照检查材料范文
2014/09/24 职场文书
个人自我剖析材料
2014/09/30 职场文书
2015年评职称工作总结范文
2015/04/20 职场文书
爱心捐书倡议书
2015/04/27 职场文书
nginx location 带斜杠【 / 】与不带的区别
2022/04/13 Servers
Python 中面向接口编程
2022/05/20 Python