网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的范文:

 

标题 ThinkPHP3.2.3实现分页的方法详解
范文
    本文实例讲述了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>共<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" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor="#FFFFFF">
          <tr>
            <td colspan="3" bgcolor="#FFFFFF">当前登录用户:{$Think.session.admin}</td>
          </tr>
          <tr>
            <td colspan="3" bgcolor="#FFFFFF">用户信息</td>
          </tr>
          <tr>
            <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>
              <td bgcolor="#FFFFFF"> {$user.id}</td>
              <td bgcolor="#FFFFFF"> {$user.account}</td>
              <td bgcolor="#FFFFFF"> {$user.pwd}</td>
            </tr>
          </foreach>
          <tr>
            <!--<td colspan="3" bgcolor="#FFFFFF"> {$page}</td>-->
            <td colspan="3" bgcolor="#FFFFFF"><div>
                {$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程序设计有所帮助。
随便看

 

在线学习网范文大全提供好词好句、学习总结、工作总结、演讲稿等写作素材及范文模板,是学习及工作的有利工具。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/20 6:43:13