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='http://www.aoyou183.cn/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
