PHP中模板分页的处理
2008-04-04 17:35
363 查看
PHP普通开发中php代码和html代码夹杂的情况中处理分页是比较简单的,也可以构建成函数的形式。最近开发中使用 Pear::DB + Smarty 的结构,于是考虑如果对模板进行分页,因为不能直接操作页面,所以就考虑生成分页字符串的形式。
因为是三层结构,类库-->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 = "上一页 | 下一页";
} elseif ($page==$pageCount && $pageCount>1) {
$pageStr = "上一页 | 下一页";
} elseif ($page>1 && $page<=$pageCount) {
$pageStr = "上一页 |
下一页";
} 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);
?>
为了更清晰的认识,下面简单的描述一下类库中的基本内容:(代码不完整)
/**
* 文件: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"}
书籍总数:{$BookTotal}
{section name=Book loop=$allBook}
.id}]{$allBook[Book].title}
{sectionelse}
目前没有书籍
{/section}
{* 分页字符串显示 *}
{"GBK"|iconv:"utf-8":$pageStr}
{* 插入底部文件 *}
{include file="Cendar/foot.html"}
那么我们抓住重点就知道,我们从PHP程序里能够控制$pagStr就是我们的分页字符串,最后它将替换到模板文件里来达到效果。
基本到这里就明白了如何再模板里进行分页处理了,当然,你也可以把分页功能写成函数,或者封装成一个类,那么就方便四处调用了。呵呵~~~
(未经授权,请勿转载以上代码)
Author:heiyeluren
Date:2005-8-2
因为是三层结构,类库-->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 = "上一页 | 下一页";
} elseif ($page==$pageCount && $pageCount>1) {
$pageStr = "上一页 | 下一页";
} elseif ($page>1 && $page<=$pageCount) {
$pageStr = "上一页 |
下一页";
} 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);
?>
为了更清晰的认识,下面简单的描述一下类库中的基本内容:(代码不完整)
/**
* 文件: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"}
书籍总数:{$BookTotal}
书籍具体内容
{section name=Book loop=$allBook}
.id}]{$allBook[Book].title}
{sectionelse}
目前没有书籍
{/section}
{* 分页字符串显示 *}
{"GBK"|iconv:"utf-8":$pageStr}
{* 插入底部文件 *}
{include file="Cendar/foot.html"}
那么我们抓住重点就知道,我们从PHP程序里能够控制$pagStr就是我们的分页字符串,最后它将替换到模板文件里来达到效果。
基本到这里就明白了如何再模板里进行分页处理了,当然,你也可以把分页功能写成函数,或者封装成一个类,那么就方便四处调用了。呵呵~~~
(未经授权,请勿转载以上代码)
Author:heiyeluren
Date:2005-8-2
相关文章推荐
- PHP中模板分页的处理
- PHP中模板分页的处理
- PHP中模板分页的处理
- html模板生成静态页面及模板分页处理
- PHP的分页处理技术和一些常用的技术
- php利用模板分页程序(带demo演示);(1/3)
- mysql远程访问 sql删除记录 伪造浏览器post php错误处理学习 django模板改tdk
- 如何简化php模板页面中分页代码的解析
- 简化php模板页面中分页代码的解析
- php基础教程——2创建模板、处理表单
- php+mysql分页处理的探讨
- php分页查询mysql结果base64处理
- php新闻内容分页实例(smarty 模板)
- PHP中轻型模板处理类:Smarty-Light
- 使用相关函数实现PHP处理分页
- 简化php模板页面中分页代码的解析
- html模板生成静态页面及模板分页处理
- php分页查询mysql结果的base64处理方法示例
- php数据库两个关联大表的大数组分页处理,防止内存溢出
- PHP中轻型模板处理类:Smarty-Light