--------------------------------------------------------------------------------
<?
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