首页 > 开发 > PHP > 正文

推荐php模板技术

2024-05-04 22:59:22
字体:
来源:转载
供稿:网友
菜鸟学堂:

 站点结构
代码:
站点
  ┗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文件 --------
[复制此代码]code:<?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);    
        }   
     }   
  }   
?> 

----------------index.htm文件-------------------
[复制此代码]code:<html>   
<head>   
<title>首页</title>   
</head>   
<body >   
<table width="100%" cellpadding="0" cellspacing="1" bgcolor=#000000 >   
    <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文件-------------------
[复制此代码]code:<tr bgcolor="#ffffff" align=center>   
  <td><a href="content.php?id={成员id}">{姓名}</a></td><td>{性别}</td><td>{年龄}</td><td>{email}</td>   
</tr> 

-------------------content.htm文件-----------------------
[复制此代码]code:<html>   
<head>   
<title>成员信息</title>   
</head>   
<body >   
<table width="100%" cellpadding="0" cellspacing="1" bgcolor=#000000 >   
    <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文件--------------------------
[复制此代码]code:<?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);    
?>

---------------- content.php文件 ---------------
[复制此代码]code:<?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]");   
  $[email protected]_fetch_row($rs);   
  unset($row[0]); //去掉表中读出的多余字段,对齐替换项,或在select语句中列表字段    
  $tags = array("姓名","性别","年龄","email");    
  echo $tmpl->parse($tags,$row);   
?>

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表