首页 > 开发 > Php > 正文

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

2020-02-21 21:03:04
字体:
来源:转载
供稿:网友

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

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

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

在这里我有先把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>            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表