推荐php模板技术[转]
程序员文章站
2022-06-01 08:28:50
站点结构 代码: 站点 ┗includes ┗class.inc...
站点结构
代码:
站点
┗includes
┗class.inc
┣templet
┗index.htm
┣list.htm
┗content.htm
┣index.php
┗content.php
库结构
代码:
-- 数据库: `test`
-- 表的结构 `test`
create table `test` (
`id` smallint(3) not null auto_increment,
`name` varchar(10) not null default '',
`sex` enum('男','女') not null default '男',
`age` smallint(2) not null default '0',
`email` varchar(20) not null default '',
primary key (`id`)
) type=myisam auto_increment=1 ;
--------------- class.inc文件 --------
----------------index.htm文件-------------------
------------------list.htm文件-------------------
-------------------content.htm文件-----------------------
----------------index.php文件--------------------------
---------------- content.php文件 ---------------
代码:
站点
┗includes
┗class.inc
┣templet
┗index.htm
┣list.htm
┗content.htm
┣index.php
┗content.php
库结构
代码:
-- 数据库: `test`
-- 表的结构 `test`
create table `test` (
`id` smallint(3) not null auto_increment,
`name` varchar(10) not null default '',
`sex` enum('男','女') not null default '男',
`age` smallint(2) not null default '0',
`email` varchar(20) not null default '',
primary key (`id`)
) type=myisam auto_increment=1 ;
--------------- class.inc文件 --------
复制代码 代码如下:
<?php
class mycon{
private $myhost;
private $myuser;
private $mypwd;
function mycon($host="localhost",$user="root",$pwd=""){
$this->myhost = $host;
$this->myuser = $user;
$this->mypwd = $pwd;
}
function connect(){
return mysql_connect($this->myhost,$this->myuser,$this->mypwd);
}
}
class templet{
private $source_file;
function get_file($filename){
$this->source_file = file_get_contents($filename);
}
function parse($tags,$vals){
if(!is_array($tags)){
return preg_replace("|{".$tags."}|",$vals,$this->source_file);
}else{
$an = count($tags);
for($i=0;$i<$an;$i++){
$tags[$i] = "|{".$tags[$i]."}|";
}
return preg_replace($tags,$vals,$this->source_file);
}
}
}
?>
class mycon{
private $myhost;
private $myuser;
private $mypwd;
function mycon($host="localhost",$user="root",$pwd=""){
$this->myhost = $host;
$this->myuser = $user;
$this->mypwd = $pwd;
}
function connect(){
return mysql_connect($this->myhost,$this->myuser,$this->mypwd);
}
}
class templet{
private $source_file;
function get_file($filename){
$this->source_file = file_get_contents($filename);
}
function parse($tags,$vals){
if(!is_array($tags)){
return preg_replace("|{".$tags."}|",$vals,$this->source_file);
}else{
$an = count($tags);
for($i=0;$i<$an;$i++){
$tags[$i] = "|{".$tags[$i]."}|";
}
return preg_replace($tags,$vals,$this->source_file);
}
}
}
?>
----------------index.htm文件-------------------
复制代码 代码如下:
<html>
<head>
<title>首页</title>
</head>
<body style="font-size:12px">
<table width="100%" cellpadding="0" cellspacing="1" bgcolor=#000000 style="font-size:12px">
<caption>成员列表</caption>
<tr bgcolor="#ffffff" align=center>
<td width=25%>姓名</td>
<td width=25%>性别</td>
<td width=25%>年龄</td>
<td width=25%>email</td>
</tr>
{所有列表}
<tr bgcolor="#ffffff">
<td colspan=2>共有{总条数}条记录,显示{每页条数}条/页</td>
<td colspan=2 align=right>{分页}</td>
</tr>
</table>
</body>
</html>
<head>
<title>首页</title>
</head>
<body style="font-size:12px">
<table width="100%" cellpadding="0" cellspacing="1" bgcolor=#000000 style="font-size:12px">
<caption>成员列表</caption>
<tr bgcolor="#ffffff" align=center>
<td width=25%>姓名</td>
<td width=25%>性别</td>
<td width=25%>年龄</td>
<td width=25%>email</td>
</tr>
{所有列表}
<tr bgcolor="#ffffff">
<td colspan=2>共有{总条数}条记录,显示{每页条数}条/页</td>
<td colspan=2 align=right>{分页}</td>
</tr>
</table>
</body>
</html>
------------------list.htm文件-------------------
复制代码 代码如下:
<tr bgcolor="#ffffff" align=center>
<td><a href="content.php?id={成员id}">{姓名}</a></td><td>{性别}</td><td>{年龄}</td><td>{email}</td>
</tr>
<td><a href="content.php?id={成员id}">{姓名}</a></td><td>{性别}</td><td>{年龄}</td><td>{email}</td>
</tr>
-------------------content.htm文件-----------------------
复制代码 代码如下:
<html>
<head>
<title>成员信息</title>
</head>
<body style="font-size:12px">
<table width="100%" cellpadding="0" cellspacing="1" bgcolor=#000000 style="font-size:12px">
<caption>成员信息</caption>
<tr bgcolor="#ffffff">
<td width=60>姓名</td><td>{姓名}</td></tr>
<tr bgcolor="#ffffff">
<td>性别</td><td>{性别}</td></tr>
<tr bgcolor="#ffffff">
<td>年龄</td><td>{年龄}</td></tr>
<tr bgcolor="#ffffff">
<td>email</td><td>{email}</td></tr>
</table>
</body>
<head>
<title>成员信息</title>
</head>
<body style="font-size:12px">
<table width="100%" cellpadding="0" cellspacing="1" bgcolor=#000000 style="font-size:12px">
<caption>成员信息</caption>
<tr bgcolor="#ffffff">
<td width=60>姓名</td><td>{姓名}</td></tr>
<tr bgcolor="#ffffff">
<td>性别</td><td>{性别}</td></tr>
<tr bgcolor="#ffffff">
<td>年龄</td><td>{年龄}</td></tr>
<tr bgcolor="#ffffff">
<td>email</td><td>{email}</td></tr>
</table>
</body>
----------------index.php文件--------------------------
复制代码 代码如下:
<?php
include("includes/class.inc");
$tmpl =new templet;
$mycon =new mycon;
$con = $mycon->connect();
mysql_select_db("test",$con);
$lim = 20; //每页显示行数
$p = ($_get[p]) ? $_get[p] : 1; //当前页号
/***** 生成列表开始 *****/
$lists = "";
$tmpl->get_file("templet/list.htm");
$tags = array("成员id","姓名","性别","年龄","email"); //应与表字段同顺序
$rs = mysql_query("select * from test order by id desc limit ".($p-1)*$lim.",$lim");
while($row=mysql_fetch_row($rs)){
$lists .= $tmpl->parse($tags,$row);
}
/***** 生成列表完成, 分页开始 *****/
$tmpl->get_file("templet/index.htm");
$rn = @mysql_result(mysql_query("select count(id) from test"),0); //总记录数
$ps = ceil($rn/$lim); //总页数
$pagination = "<a href='?p=1'>首页</a> ";
if($p>1) $pagination .= "<a href='?p=".($p-1)."'>";
else $pagination .= "<font color='#777777'>";
$pagination .= "上一页</font></a> ";
if($p<$ps) $pagination .= "<a href='?p=".($p+1)."'>";
else $pagination .= "<font color='#777777'>";
$pagination .= "下一页</font></a> <a href='?p={$ps}'>尾页</a> ";
/***** 分页完成, 生成页面开始 *****/
$tags = array("所有列表","总条数","每页条数","分页");
$vals = array($lists,$rn,$lim,$pagination);
echo $tmpl->parse($tags,$vals);
?>
include("includes/class.inc");
$tmpl =new templet;
$mycon =new mycon;
$con = $mycon->connect();
mysql_select_db("test",$con);
$lim = 20; //每页显示行数
$p = ($_get[p]) ? $_get[p] : 1; //当前页号
/***** 生成列表开始 *****/
$lists = "";
$tmpl->get_file("templet/list.htm");
$tags = array("成员id","姓名","性别","年龄","email"); //应与表字段同顺序
$rs = mysql_query("select * from test order by id desc limit ".($p-1)*$lim.",$lim");
while($row=mysql_fetch_row($rs)){
$lists .= $tmpl->parse($tags,$row);
}
/***** 生成列表完成, 分页开始 *****/
$tmpl->get_file("templet/index.htm");
$rn = @mysql_result(mysql_query("select count(id) from test"),0); //总记录数
$ps = ceil($rn/$lim); //总页数
$pagination = "<a href='?p=1'>首页</a> ";
if($p>1) $pagination .= "<a href='?p=".($p-1)."'>";
else $pagination .= "<font color='#777777'>";
$pagination .= "上一页</font></a> ";
if($p<$ps) $pagination .= "<a href='?p=".($p+1)."'>";
else $pagination .= "<font color='#777777'>";
$pagination .= "下一页</font></a> <a href='?p={$ps}'>尾页</a> ";
/***** 分页完成, 生成页面开始 *****/
$tags = array("所有列表","总条数","每页条数","分页");
$vals = array($lists,$rn,$lim,$pagination);
echo $tmpl->parse($tags,$vals);
?>
---------------- content.php文件 ---------------
复制代码 代码如下:
<?php
include("includes/class.inc");
$tmpl =new templet;
$mycon =new mycon;
$con = $mycon->connect();
mysql_select_db("test",$con);
$tmpl->get_file("templet/content.htm");
$rs = mysql_query("select * from test where id=$_get[id]");
$row=@mysql_fetch_row($rs);
unset($row[0]); //去掉表中读出的多余字段,对齐替换项,或在select语句中列表字段
$tags = array("姓名","性别","年龄","email");
echo $tmpl->parse($tags,$row);
?>
include("includes/class.inc");
$tmpl =new templet;
$mycon =new mycon;
$con = $mycon->connect();
mysql_select_db("test",$con);
$tmpl->get_file("templet/content.htm");
$rs = mysql_query("select * from test where id=$_get[id]");
$row=@mysql_fetch_row($rs);
unset($row[0]); //去掉表中读出的多余字段,对齐替换项,或在select语句中列表字段
$tags = array("姓名","性别","年龄","email");
echo $tmpl->parse($tags,$row);
?>