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处理类
* 作者: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
新闻热点
疑难解答