PHP中模板分页的处理
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) && !empty($_GET)) { $page = intval($_GET); } 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.mypchelp.cn* 作者: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='https://www.haobala.com/bcjs/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:heiyelurenDate:2005-8-2