php普通开发中php代码和html代码夹杂的情况中处理分页是比较简单的,也可以构建成函数的形式。最近开发中使用 Pear::DB + Smarty 的结构,于是考虑如果对模板进行分页,因为不能直接操作页面,所以就考虑生成分页字符串的形式。 因为是三层结构,类库-->PHP调用-->模板的形式,所有的数据处理是在类库里的,那么分页控制就在PHP调用中进行的,模板就复杂解析调用的结果。先直接看我们PHP调用中的分页代码: -------------------------------------------------------------------------------- <?php /** * 文件:Type.php * 功能:显示类别下的书籍 * 作者:heiyeluren **/ //包含公共文件,包括类库等 require_once("include.php"); //实例化操作对象 $Type = new CTypes(); //每页记录数 define("PAGE_SIZE", 10); //获取GET提交的变量 $TypeID = $tid ? $tid : intval($_REQUEST['tid']); //书籍总数 $BookTotal = $Type->getBookTotal($TypeID); /* 分页显示核心 */ //获取总页数 $pageCount = ($BookTotal/PAGE_SIZE); //当前页数 if (isset($_GET[page]) && !empty($_GET[page])) { $page = intval($_GET[page]); } else { $page = 1; } if ($page==1) { $startNum = 0; } else { $startNum = ($page-1) * PAGE_SIZE; } //生成分页链接字符串 if ($page==1 && $pageCount>1) { $pageStr = "上一页 | <a href=/Type.php?tid=".$TypeID."&page=".($page+1).">下一页</a>"; } elseif ($page==$pageCount && $pageCount>1) { $pageStr = "<a href=/Type.php?tid=".$TypeID."&page=".($page-1).">上一页</a> | 下一页"; } elseif ($page>1 && $page<=$pageCount) { $pageStr = "<a href=/Type.php?tid=".$TypeID."&page=".($page-1).">上一页</a> | <a href=/Type.php?tid=".$TypeID."&page=".($page+1).">下一页</a>"; } else { $pageStr = "上一页 | 下一页"; } //按照页数获取当前记录 $allBook = $Type->getBookFromType($TypeID, $start=$startNum, $offset=PAGE_SIZE); //Smarty变量赋值 $tpl->assign('BookTotal', $BookTotal); $tpl->assign('allBook', $allBook); $tpl->assign('pageStr', $pageStr); $tpl->display('Type.html'); unset($Type); ?> --------------------------------------------------------------------------------
为了更清晰的认识,下面简单的描述一下类库中的基本内容:(代码不完整) -------------------------------------------------------------------------------- <?php /** * 文件:Type.class.php * 功能:Type处理类 * www.knowsky.com * 作者:heiyeluren **/ class Type { var $mDsn; var $mTableName; var $hPearDB; //构造函数 function Type() { //... } //获得pear DB类的句柄方法 function _getDBClass($fetchMode = DB_FETCHMODE_ASSOC) { if(!is_object($this->hPearDB)){ $this->hPearDB = DB::connect($this->mDsn); $this->hPearDB->query("set names 'utf8'"); $this->hPearDB->setFetchMode($fetchMode); if(DB::IsError($this->hPearDB)){ return false; } } return $this->hPearDB; } //获取书籍总数 function getBookTotal($TypeId) { $db = $this->_getDBClass(); $sql = "SELECT COUNT(*) AS total FROM ..."; $rs = $db->getOne($sql); if (DB::isError($rs)) return $rs->getMessage(); else return $rs; } //获取所有书籍 function getBookFromType($TypeId, $start, $offset) { $db = $this->_getDBClass(); $sql = "SELECT * FROM ... LIMIT $start,$offset"; $rs = $db->getAll($sql); if (DB::isError($rs)) return $rs->getMessage(); else return $rs; } } ?> --------------------------------------------------------------------------------
最后再让我们看一下这个Type.html模板是如何处理的:
-------------------------------------------------------------------------------- {* 插入头部文件 *} {include file="Cendar/head.html"} <div id="side"> <ul> <li>书籍总数:{$BookTotal}</li> </ul> </div> <div id="Book"> <h2 class="cata">书籍具体内容</h2> <ul> {section name=Book loop=$allBook} <li><a href="show_Book.php?tid={$allBook[Book].id}">{$allBook[Book].title}</a></li> {sectionelse} <li class="warning">目前没有书籍</li> {/section} </ul> </div> {* 分页字符串显示 *} <div align="right"> {"GBK"|iconv:"utf-8":$pageStr} </div> {* 插入底部文件 *} {include file="Cendar/foot.html"} -------------------------------------------------------------------------------- 那么我们抓住重点就知道,我们从PHP程序里能够控制$pagStr就是我们的分页字符串,最后它将替换到模板文件里来达到效果。
基本到这里就明白了如何再模板里进行分页处理了,当然,你也可以把分页功能写成函数,或者封装成一个类,那么就方便四处调用了。呵呵~~~ (未经授权,请勿转载以上代码) Author:heiyeluren Date:2005-8-2 注意:联系我时,请一定说明是从【S】看到的信息,谢谢。 |