接下来我们先开始写显示留言的程序
-------------------------------------------------------------------------------
为了简要,我们在这里建一个简单的表guestbook,字段三个gb_id,gb_name,gb_content
表建好后,填几条记录方便测试 (附:我这里用的数据库是mysql)
接着写个数据库连接程序gb_conn.inc.php放在inc目录下
代码如下:
<?php
mysql_connect("localhost","root","") or die("Sorry,can't connect data server!");
mysql_select_db("test") or die("Sorry,can't open database!");
extract($_GET);
extract($_POST);
?>
再写一个分页处理的函数,写进gb_function.php,文件放在function里
<?php
/*==============================================================================
*
* 文 件 名: gb_function.php
* 程序功能: 自定义函数集
* 更新时间: 2004-09-02
*
* 程序设计: Jzealot
* E-mail : web-xy@163.com
*
*===============================================================================*/
/*******************************************
函 数 名: pagedeal()
函数功能: 分页处理
*******************************************/
function pagedeal($pagesql, $pagesize)
{
global $recordcount, $pagecount, $page, $startloc;
$rs = mysql_query($pagesql);
$recordcount = mysql_num_rows($rs); //取得记录总数
//******计算总页数*******/
if ( $recordcount % $pagesize == 0 )
$pagecount = $recordcount / $pagesize;
else
$pagecount = intval($recordcount / $pagesize) + 1;
if ( empty($page)||$page<1 )//$page是当前页
$page = 1;
if ( $page>$pagecount )
$page = $pagecount;
$startloc = ($page - 1) * $pagesize;//确定当前页的起始记录
//-----------------当前页的前部分数字分页----------------------//
if ($page<=5);
$i = 0;
if ( $page>5 && $pagecount - $page < 5 && $pagecount>10 )
$i = $pagecount - 10;
if ($page>5 && $pagecount - $page >=5)
$i = $page - 5;
for (; $i < $page; $i++)
$numpage[$i] = $i + 1;
//--------------当前页的后半部分(包括当前页)数字分页------------//
$j = $pagecount;
if ($page<=5 && $pagecount>10)
$j = 10;
if ($page>5 && $pagecount - $page >=5)
$j = $page + 5;
for (; $i<$j; $i++)
$numpage[$i] = $i+1;
return $numpage;//返回数字分页
}
?>
最后我们再写留言显示程序gb_list.php
<?php
/*==============================================================================
*
* 文 件 名: gb_list.php
* 程序功能: 显示留言
* 更新时间: 2004-09-02
*
* 程序设计: Jzealot
* E-mail : web-xy@163.com
*
*===============================================================================*/
include_once("inc/gb_conn.inc.php");//载入数据库连接&请求设置
include_once("inc/smarty.inc.php");//载入smarty设置
include_once("function/gb_function.php");
//--------------------------------------------------------------------------------
//分页处理查询数据
//--------------------------------------------------------------------------------
$sql = "select gb_id from guestbook";
$pagesize = 5;
$fpage = "gb_list.php";
$numpage = pagedeal($sql,$pagesize);//调用分页处理函数
//----------------------分页相关的模板变量替换-------------------------//
$smarty -> assign("recordcount", $recordcount);//总记录数
$smarty -> assign("page", $page); //当前页
$smarty -> assign("pagecount", $pagecount); //总页数
$smarty -> assign("prepage", $page-1); //上一页
$smarty -> assign("nexpage", $page+1); //下一页
$smarty -> assign("numpage", $numpage); //数字分页
$smarty -> assign("fpage", $fpage); //要分页的网页
//-------------------------------------------------------------------------------
//查询数据并传递到模板
//-------------------------------------------------------------------------------
$rs = mysql_query("select * from guestbook limit $startloc,$pagesize");
$num = 0;
while ( $row = mysql_fetch_array($rs) )
{
$rss[$num] = array("gb_name" => $row["gb_name"], "gb_content" => $row["gb_content"]);
$num++;
}
$smarty -> assign("rss",$rss);
$smarty -> display('gb_list.tpl');//显示模板
?>
下次说说模板的写法
(续)